

# TRONICS ST6240 8-BIT HCMOS MCU WITH LCD DRIVER, EEPROM AND A/D CONVERTER

- 3 to 6V supply operating range
- 8.4MHz Maximum Clock Frequency
- -40 to +85°C Operating Temperature Range
- Run, Wait & Stop Modes
- 5 different interrupt vectors
- Look-up table capability in ROM

| User ROM: | 7948 | bytes |
|-----------|------|-------|
| Data RAM: | 192  | bytes |
| LCD RAM:  | 24   | bytes |
| EEPROM:   | 128  | bytes |

- PQFP80 package
- 16 fully software programmable I/O as:
   Input with/without pull-up resistor
  - Input with interrupt generation
  - Open-Drain or Push-pull outputs
  - Analog Inputs (12 pins)
- 4 I/O lines can sink up to 20mA for direct LED or TRIAC driving, and have SPI alternate functions
- Two 8-bit counters with 7-bit programmable prescalers (Timers 1 and 2)
- Software or hardware activated digital watchdog
- 8-bit A/D converter with up to 12 analog inputs
- 8-bit synchronous Serial Peripheral Interface (SPI)
- LCD driver with 45 segment outputs, 4 backplane outputs and selectable duty cycle for up to 180 LCD segments direct driving
- 32kHz oscillator for stand-by LCD operation
- Power Supply Supervisor (PSS)
- One external not maskable interrupt
- 9 powerful addressing modes
- The accumulator, the X, Y, V & W registers, the port and peripherals data & control registers are addressed in the data space as RAM locations.
- The ST62E40 is the EPROM version, ST62T40 is the OTP version
- Development tool: ST6240-EMU connected via RS232 to an MS-DOS Personal Computer



# ST624x DATASHEET INDEX -

| Ρ | а | a | e | s |
|---|---|---|---|---|
|   | α | ы | C | 9 |

| ST6240                               |
|--------------------------------------|
| GENERAL DESCRIPTION                  |
| PIN DESCRIPTION                      |
| ST62xx CORE                          |
| MEMORY SPACES                        |
| TEST MODE                            |
| INTERRUPTS                           |
| RESET                                |
| WAIT & STOP MODES                    |
| ON-CHIP CLOCK OSCILLATOR             |
| INPUT/OUTPUT PORTS                   |
| TIMERS                               |
| DIGITAL WATCHDOG                     |
| 8-BIT A/D CONVERTER                  |
| POWER SUPPLY SUPERVISOR DEVICE (PSS) |
| 32kHz STAND-BY OSCILLATOR 44         |
| SERIAL PERIPHERAL INTERFACE (SPI)    |
| LCD CONTROLLER-DRIVER                |
| SOFTWARE DESCRIPTION                 |
| ELECTRICAL CHARACTERISTICS           |
| PACKAGE MECHANICAL DATA              |
| ORDERING INFORMATION                 |
| ST62E40 / ST62T40                    |
| GENERAL DESCRIPTION                  |
| PIN DESCRIPTION                      |
| ST62E40.T40 EPROM/OTP DESCRIPTION    |
| ELECTRICAL CHARACTERISTICS           |
| PACKAGE MECHANICAL DATA              |
| ORDERING INFORMATION TABLE           |
|                                      |



# ST624x DATASHEET INDEX -

| ST6242                            |
|-----------------------------------|
| GENERAL DESCRIPTION               |
| PIN DESCRIPTION                   |
| ST62xx CORE                       |
| MEMORY SPACES                     |
| TEST MODE                         |
| INTERRUPTS                        |
| RESET                             |
| WAIT & STOP MODES                 |
| ON-CHIP CLOCK OSCILLATOR          |
| INPUT/OUTPUT PORTS                |
| TIMERS                            |
| DIGITAL WATCHDOG                  |
| 8-BIT A/D C ONVERTER              |
| SERIAL PERIPHERAL INTERFACE (SPI) |
| LCD CONTROLLER-DRIVER             |
| SOFTWARE DESCRIPTION              |
| ELECTRICAL CHARACTERISTICS        |
| PACKAGE MECHANICAL DATA           |
| ORDERING INFORMATION              |
| ST62E42 / ST62T42 143             |
| GENERAL DESCRIPTION               |
| PIN DESCRIPTION                   |
| ST62E42,T42 EPROM/OTP DESCRIPTION |
| ELECTRICAL CHARACTERISTICS        |
| PACKAGE MECHANICAL DATA           |
| ORDERING INFORMATION TABLE        |



# — ST624x DATASHEET INDEX —

| ST6245                            | 157        |
|-----------------------------------|------------|
| GENERAL DESCRIPTION               | 159        |
| PIN DESCRIPTION                   | 160        |
| ST62xx CORE                       | 161        |
| MEMORY SPACES                     | 163        |
| TEST MODE                         | 170        |
| INTERRUPTS                        | 170        |
| RESET                             | 175        |
| WAIT & STOP MODES                 | 178        |
| ON-CHIP CLOCK OSCILLATOR          | 179        |
| INPUT/OUTPUT PORTS                | 181        |
| TIMERS                            | 185        |
| DIGITAL WATCHDOG                  | 188        |
| 8-BIT A/D CONVERTER               | 190        |
| 32kHz STAND-BY OSCILLATOR         | 192        |
| SERIAL PERIPHERAL INTERFACE (SPI) | 193        |
| LCD CONTROLLER-DRIVER             | 195        |
| SOFTWARE DESCRIPTION              | 201        |
| ELECTRICAL CHARACTERISTICS        | 206        |
| PACKAGE MECHANICAL DATA           | 214        |
| ORDERING INFORMATION              | 216        |
|                                   |            |
| ST62E45 / ST62T45                 | 219        |
|                                   | 221        |
|                                   | 221        |
|                                   | 222        |
|                                   | 223<br>224 |
|                                   | 224        |
|                                   | 231        |
| ORDERING INFORMATION TABLE        | ZSZ        |



# Figure 1. 80 Pin Quad Flat Pack (QFP) Package Pinout



# ST6240 Pin Description

| Pin<br>number | Pin<br>name     | Pin<br>number | Pin<br>name             | Pin<br>number | Pin<br>name | Pin<br>number | Pin<br>name |
|---------------|-----------------|---------------|-------------------------|---------------|-------------|---------------|-------------|
| 1             | S43             | 25            | RESET                   | 64            | S26         | 65            | S27         |
| 2             | S44             | 26            | OSCout                  | 63            | S25         | 66            | S28         |
| 3             | S45             | 27            | OSCin                   | 62            | S24         | 67            | S29         |
| 4             | S46             | 28            | WDON                    | 61            | S23         | 68            | S30         |
| 5             | S47             | 29            | NMI                     | 60            | S22         | 69            | S31         |
| 6             | S48             | 30            | TIMER                   | 59            | S21         | 70            | S32         |
| 7             | COM4            | 31            | PB7/Sout <sup>(1)</sup> | 58            | S20         | 71            | S33         |
| 8             | COM3            | 32            | PB6/Sin <sup>(1)</sup>  | 57            | S19         | 72            | S34         |
| 9             | COM2            | 33            | PB5/SCL <sup>(1)</sup>  | 56            | S18         | 73            | S35         |
| 10            | COM1            | 34            | PB4 <sup>(1)</sup>      | 55            | S17         | 74            | S36         |
| 11            | VLCD1/3         | 35            | PB3/Ain                 | 54            | S16         | 75            | S37         |
| 12            | VLCD2/3         | 36            | PB2/Ain                 | 53            | S15         | 76            | S38         |
| 13            | VLCD            | 37            | PB1/Ain                 | 52            | S14         | 77            | S39         |
| 14            | PA7/Ain         | 38            | PB0/Ain                 | 51            | S13         | 78            | S40         |
| 15            | PA6/Ain         | 39            | OSC32out                | 50            | S12         | 79            | S41         |
| 16            | PA5/Ain         | 40            | OSC32in                 | 49            | S11         | 80            | S42         |
| 17            | PA4/Ain         |               |                         | 48            | S10         |               |             |
| 18            | TEST            |               |                         | 47            | S9          |               |             |
| 19            | PA3/Ain         |               |                         | 46            | S8          |               |             |
| 20            | PA2/Ain         |               |                         | 45            | S7          |               |             |
| 21            | PA1/Ain         |               |                         | 44            | S6          |               |             |
| 22            | PA0/Ain         |               |                         | 43            | S5          |               |             |
| 23            | V <sub>DD</sub> |               |                         | 42            | S4          |               |             |
| 24            | V <sub>SS</sub> |               |                         | 41            | PSS         |               |             |

Note 1: 20mA Sink



#### **GENERAL DESCRIPTION**

The ST6240 microcontroller is a member of the 8-bit HCMOS ST62xx family, a series of devices oriented to low-medium complexity applications. All ST62xx members are based on a building block approach: a common core is associated with a combination of on-chip peripherals (macrocells). The macrocells of the ST6240 are: a high performance LCD controller/driver with 45 segment outputs and 4 backplanes able to drive up to 180 segments, two Timer peripherals each including an 8-bit counter with a 7-bit software programmable prescaler (Timer), the digital watchdog (DWD), an 8-bit A/D Converter with up to 12 analog inputs, a Power Supply Supervisor and an 8-bit synchronous Serial Peripheral Interface (SPI). In addition these devices offer 128 bytes of EEPROM for storage of non volatile data. Thanks to these peripherals the ST6240 is well suited for general purpose, automotive, security, appliance and industrial applications. The ST62E40 EPROM version is available for prototypes and low-volume production, an OTP version is also available (see separate datasheet).





Note:

Ain= Analog Input



#### **PIN DESCRIPTION**

 $V_{DD}$  and  $V_{SS}.$  Power is supplied to the MCU using these two pins.  $V_{DD}$  is power and  $V_{SS}$  is the ground connection.

**OSCin and OSCout**. These pins are internally connected with the on-chip oscillator circuit. A quartz crystal or a ceramic resonator can be connected between these two pins in order to allow the correct operation of the MCU with various stability/cost trade-offs. OSCin is the input pin, OSCout is the output pin. An external clock signal can be applied to OSCin.

**RESET.** The active low **RESET** pin is used to restart the microcontroller at the beginning of its program. The **RESET** pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TEST.** The TEST must be held at  $V_{SS}$  for normal operation (an internal pull-down resistor selects normal operating mode if TEST pin is not connected).

**NMI.** The NMI pin provides the capability for asynchronous applying an external top priority interrupt to the MCU. This pin is falling edge sensitive. The NMI pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TIMER.** This is the TIMER 1 I/O pin. In input mode it is connected to the prescaler and acts as external timer clock or as control gate for the internal timer clock. In the output mode the TIMER pin outputs the data bit when a time-out occurs.

**WDON.** This pin selects the watchdog enabling option (hardware or software). A low level selects the hardware activated option (the watchdog is always active), a high level selects the software activated option (the watchdog can be activated by software, deactivated only by reset, thus enabling STOP mode). An internal pull-up resistance selects the software watchdog option if the WDON pin is not connected.

**PA0-PA7.** These 8 lines are organized as one I/O port (A). Each line may be configured under software control as an input with or without pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output or as analog input for the A/D converter. Port A has a 5mA drive capability in output mode.

**PB0-PB3,PB4-PB7.** These 8 lines are organized as one I/O port (B). Each line may be configured under software control as an input with or without internal pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output. PB0-PB3 can be programmed as analog inputs for the A/D converter while PB4-PB7 can also sink 20mA for direct LED driving. PB5-PB7 can also be used as respectively Clock, Data in and Data out pins for the on-chip SPI to carry the synchronous serial I/O signals.

**COM1-COM4.** These four pins are the LCD peripheral common outputs. They are the outputs of the on-chip backplane voltage generator which is used for multiplexing the 45 LCD lines allowing up to 180 segments to be driven.

**S4-S48.** These pins are the 45 LCD peripheral driver outputs of ST6240. Segments S1-S3 are not connected to any pin.

**VLCD.** Display voltage supply. It determines the high voltage level on COM1-COM4 and S4-S48 pins.

VLCD1/3, VLCD2/3. Display supply voltage inputs for determining the display voltage levels on COM1-COM4 and S4-S48 pins during multiplex operation.

**PSS.** This is the Power Supply Supervisor sensing pin. When the voltage applied to this pin is falling below a software programmed value the highest priority (NMI) interrupt can be generated. This pin has to be connected to the voltage to be supervised.

**OSC32in and OSC32out.** These pins are internally connected with the on-chip 32kHz oscillator circuit. A 32.768kHz quartz crystal can be connected between these two pins if it is necessary to provide the LCD stand-by clock and real time interrupt. OSC32in is the input pin, OSC32out is the output pin.



#### ST62xx CORE

The core of the ST62xx Family is implemented independently from the I/O or memory configuration. Consequently, it can be treated as an independent central processor communicating with I/O and memory via internal addresses, data, and control busses. The in-core communication is arranged as shown in Figure 3; the controller being externally linked to both the reset and the oscillator, while the core is linked to the dedicated on-chip macrocells peripherals via the serial data bus and indirectly for interrupt purposes through the control registers.

#### Registers

The ST62xx Family core has six registers and three pairs of flags available to the programmer. They are shown in Figure 4 and are explained in the following paragraphs.

Accumulator (A). The accumulator is an 8-bit general purpose register used in all arithmetic calculations, logical operations, and data manipulations. The accumulator is addressed in the data space as RAM location at address FFh. Accordingly, the ST62xx instruction set can use the accumulator as any other register of the data space.







#### Figure 4. ST62xx Core Programming Model



#### ST62xx CORE (Continued)

**Indirect Registers (X, Y).** These two indirect registers are used as pointers to memory locations in the data space. They are used in the register-indirect addressing mode. These registers can be addressed in the data space as RAM locations at addresses 80h (X) and 81h (Y). They can also be accessed with the direct, short direct, or bit direct addressing modes. Accordingly, the ST62xx instruction set can use the indirect registers as any other register of the data space.

**Short Direct Registers (V, W).** These two registers are used to save one byte in short direct addressing mode. These registers can be addressed in the data space as RAM locations at addresses 82h (V) and 83h (W). They can also be accessed with the direct and bit direct addressing modes. Accordingly, the ST62xx instruction set can use the short direct registers as any other register of the data space.

## **Program Counter (PC)**

The program counter is a 12-bit register that contains the address of the next ROM location to be processed by the core. This ROM location may be an opcode, an operand, or an address of operand. The 12-bit length allows the direct addressing of 4096 bytes in the program space. Nevertheless, if the program space contains more than 4096 locations, as for the ST6240, the further program space can be addressed by using the Program ROM Page register.

The PC value is incremented after it is read from the address of the current instruction. To execute relative jumps the PC and the offset are shifted through the ALU, where they will be added, and the result is shifted back into the PC. The program counter can be changed in the following ways:

| - JP (Jump) instruction        | PC=Jump address     |
|--------------------------------|---------------------|
| - CALL instruction             | PC=Call address     |
| - Relative Branch instructions | $PC=PC \pm offset$  |
| - Interrupt                    | PC=Interrupt vector |
| - Reset                        | PC=Reset vector     |
| - RET & RETI instructions .    | PC=Pop (stack)      |
| - Normal instruction           | PC=PC+1             |

## Flags (C, Z)

The ST62xx core includes three pairs of flags that correspond to 3 different modes: normal mode, interrupt mode and Non-Maskable Interrupt-Mode. Each pair consists of a CARRY flag and a ZERO flag. One pair (CN, ZN) is used during normal operation, one pair is used during the interrupt mode (CI, ZI) and one is used during the not-maskable interrupt mode (CNMI, ZNMI).

The ST62xx core uses the pair of flags that correspond to the actual mode: as soon as an interrupt (resp. a Non-Maskable-Interrupt) is generated, the ST62xx core uses the interrupt flags (resp. the NMI flags) instead of the normal flags. When the RETI instruction is executed, the normal flags (resp. the interrupt flags) are restored if the MCU was in the normal mode (resp. in the interrupt mode) before the interrupt. It should be observed that each flag set can only be addressed in its own mode (Notmaskable interrupt, normal interrupt or main mode). The flags are not cleared during the context switching and so remain in the state they were at the exit of the last mode switch.

The Carry flag is set when a carry or a borrow occurs during arithmetic operations, otherwise it is cleared. The Carry flag is also set to the value of the bit tested in a bit test instruction, and participates in the rotate left instruction.

The Zero flag is set if the result of the last arithmetic or logical operation was equal to zero, otherwise it is cleared.

The switching between the three sets of Flags is automatically performed when an NMI, an interrupt or a RETI instruction occurs. As the NMI mode is automatically selected after the reset of the MCU, the ST62xx core uses at first the NMI flags.



#### ST62xx CORE (Continued)

#### Stack

The ST62xx core includes a true LIFO hardware stack that eliminates the need for a stack pointer. The stack consists of six separate 12-bit RAM locations that do not belong to the data space RAM area. When a subroutine call (or interrupt request) occurs, the contents of each level is shifted into the next level while the content of the PC is shifted into the first level (the value of the sixth level will be lost). When a subroutine or interrupt return occurs (RET or RETI instructions), the first level register is shifted back into the PC and the value of each level is popped back into the previous level. These two operating modes are described in Figure 5. Since the accumulator, as all other data space registers, is not stored in the stack, the handling of these registers should be performed inside the subroutine. The stack pointer will remain in its deepest position if more than 6 calls or interrupts are executed, so that the last return address will be lost. It will also remain in its highest position if the stack is empty and a RET or RETI is executed. In this case the next instruction will be executed.

## Figure 5. Stack Operation



#### **MEMORY SPACES**

The MCU operates in three different memory spaces: program space, data space, and stack space. A description of these spaces is shown in the following figures.

#### **Program Space**

The program space is physically implemented in the ROM memory and includes all the instructions that are to be executed, as well as the data required for the immediate addressing mode instructions, the reserved test area and the user vectors. It is addressed by the 12-bit Program Counter register (PC register) and so the ST62xx core can directly address up to 4K bytes of Program Space. Nevertheless, the Program Space can be extended by the addition of 2Kbyte ROM banks as it is shown in the following figure in which the ST6240 8Kbyte memory is described.

# Figure 6. ST6240 8Kbytes Program Space Addressing Description





#### Figure 7. ST62xx Memory Addressing Description Diagram



These banks are addressed in the 000h-7FFh locations of the Program Space by the Program Counter and by writing the appropriate code in the Program ROM Page Register (PRPR register) located at address CAh of the Data Space. Because interrupts and common subroutines should be available all the time, only the lower 2K byte of the 4K program space are bank switched while the upper 2K byte can be seen as static page. Table 2 gives the different codes that allow the selection of the corresponding banks. Note that, from the memory point of view, Page 1 and the Static Page represent the same physical memory: it is only two different ways of addressing the same locations. On the ST6240 a total of 8192 bytes of ROM have been implemented; 7948 are available as user ROM while 244 are reserved for SGS-THOMSON test purposes.

Table 1. ST6240 Program ROM Memory Map

| ROM Page           | Device Address                                                                         | Description                                                                            |
|--------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| Page 0             | 0000h-007Fh<br>0080h-07FFh                                                             | Reserved<br>User ROM                                                                   |
| Page 1<br>"STATIC" | 0800h-0F9Fh<br>0FA0h-0FEFh<br>0FF0h-0FF7h<br>0FF8h-0FFBh<br>0FFCh-0FFDh<br>0FFEh-0FFFh | User ROM<br>Reserved<br>Interrupt<br>Vectors<br>Reserved<br>NMI Vector<br>Reset Vector |
| Page 2             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                   |
| Page 3             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                   |



#### **Data Space**

The instruction set of the ST62xx core operates on a specific space, named Data Space, that contains all the data necessary for the processing of the program. The Data Space allows the addressing of RAM memory, ST62xx core/peripheral registers, and read-only data such as constants and look-up tables.

**Data ROM.** All the read-only data is physically implemented in the ROM memory in which the Program Space is also implemented. The ROM memory contains consequently the program to be executed, the constants and the look-up tables needed for the program.

The locations of Data Space in which the different constants and look-up tables are addressed by the ST62xx core can be considered as being a 64-byte window through which it is possible to access to the read-only data stored in the ROM memory.

**Data RAM/EEPROM**. The ST6240 offers 192 bytes of data RAM memory and 128 bytes of EEPROM. 64 bytes of RAM are directly addressed in data space in the range 080h-0BFh (static space). The additional RAM and the EEPROM are addressed using the banks of 64 bytes located between addresses 00h and 3Fh.

Additionally RAM are available in the LCD data map from E0h to F7h and are not banked.

#### Stack Space

The stack space consists of six 12 bit registers that are used for stacking subroutine and interrupt return addresses plus the current program counter register.

#### Figure 8. ST6240 Data Memory Space

|                                              | 000h         |
|----------------------------------------------|--------------|
|                                              | 000h         |
| DATA RAM/EEPROM BANK AREA                    | 005          |
|                                              | 03Fh         |
|                                              | 040h         |
| DATA ROM WINDOW AREA                         |              |
|                                              | 07Fh         |
| X REGISTER                                   | 080h         |
| Y REGISTER                                   | 081h         |
| V REGISTER                                   | 082h         |
| W REGISTER                                   | 083h         |
| DATA RAM 60 BYTES                            | 084h<br>0BFh |
|                                              |              |
| PORT A DATA REGISTER<br>PORT B DATA REGISTER | 0C0h<br>0C1h |
|                                              |              |
| SPIINT.DISABLE REGISTER                      | 0C2h*        |
|                                              | 0C3h         |
| PORT A DIRECTION REGISTER                    | 0C4h         |
| PORT B DIRECTION REGISTER                    | 0C5h         |
| RESERVED                                     | 0C6h         |
|                                              | 0C7h         |
|                                              | 0C8h*        |
| DATA ROM WINDOW REGISTER                     | 0C9h*        |
| PROGRAM ROM PAGE REGISTER                    | 0CAh*        |
| DATA RAM/EEPROM BANK REGISTER                | 0CBh*        |
| PORT A OPTION REGISTER                       | 0CCh         |
| RESERVED                                     | 0CDh         |
| PORTB OPTION REGISTER                        | 0CEh         |
| RESERVED                                     | 0CFh         |
| A/D DATAREGISTER                             | 0D0h         |
| A/D CONTROL REGISTER                         | 0D1h         |
| TIMER 1 PRESCALER REGISTER                   | 0D2h         |
| TIMER 1 COUNTER REGISTER                     | 0D3h         |
| TIMER 1 STATUS/CONT REGISTER                 | 0D4h         |
| TIMER 2 PRESCALER REGISTER                   | 0D5h         |
| TIMER 2 COUNTER REGISTER                     | 0D6h         |
| TIMER 2 STATUS/CONT REGISTER                 | 0D7h         |
| WATCHDOG REGISTER                            | 0D8h         |
| RESERVED                                     | 0D9h         |
| PSS STATUS/CONTROL REGISTER                  | 0DAh         |
| 32kHz OSC. CONTROL REGISTER                  | 0DBh         |
| LCD MODE CONTROL REGISTER                    | 0DCh         |
| SPI DATA REGISTER                            | 0DDh         |
| RESERVED                                     | 0DEh         |
| EEPROM CONTROL REGISTER                      | 0DFh         |
| LCD RAM                                      | 0E0h         |
|                                              | 0F7h         |
| DATA RAM 7 BYTES                             | 0F8h         |
| Brandow / Bried                              | 0FEh         |
| ACCUMULATOR                                  | 0FFh         |

\* WRITE ONLY REGISTER



#### Program ROM Page Register (PRPR)

The PRPR register can be addressed like a RAM location in the Data Space at the address CAh; nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to select the 2-Kbyte ROM bank of the Program Space that will be addressed. The number of the page has to be loaded in the PRPR register. Refer to the Program Space description for additional information concerning the use of this register. The PRPR register is not modified when an interrupt or a subroutine occurs.

Care is required when handling the PRPR register as it is write only. For this reason, it is not allowed to change the PRPR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. This operation may be necessary if common routines and interrupt service routines take more than 2K bytes; in this case it could be necessary to divide the interrupt service routine into a (minor) part in the static page (start and end) and to a second (major) part in one of the dynamic pages. If it is impossible to avoid the writing of this register in interrupt service routines, an image of this register must be saved in a RAM location, and each time the program writes to the PRPR it must write also to the image register. The image register must be written before PRPR, so if an interrupt occurs between the two instructions the PRPR is not affected.

# PRPR Program ROM Page Register (CAh, Write Only) D7 D6 D5 D4 D3 D2 D1 D0 PRPR0 Prog. ROM Select 0 PRPR1 Prog. ROM Select 1 Unused

Figure 9. Program ROM Page Register



**PRPR1-PRPR0.** These are the program ROM banking bits and the value loaded selects the corresponding page to be addressed in the lower part of the 4K program address space as specified in Table 2.

# Table 2. ST6240 8Kbytes Program ROM PageRegister Coding

| PRPR1 | PRPR0 | PC bit 11 | Memory Page          |
|-------|-------|-----------|----------------------|
| Х     | Х     | 1         | Static Page (Page1)  |
| 0     | 0     | 0         | Page 0               |
| 0     | 1     | 0         | Page 1 (Static Page) |
| 1     | 0     | 0         | Page 2               |
| 1     | 1     | 0         | Page 3               |

This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

#### Note:

Only the lower part of address space is bank switched because interrupt vectors and common subroutines should be available at all times. The reason of this structure is due to the fact that it is not possible to jump from one dynamic page to another except by jumping back to the static page, changing contents of PRPR, and then jumping to a different dynamic page.



#### Data Window register (DWR)

The Data ROM window is located from address 040h to address 7Fh in the Data space. It allows the direct reading of 64 consecutive bytes located anywhere in the ROM memory between the addresses 0000h and 1FFFh. All the bytes of the ROM memory can be used to store either instructions or read-only data. Indeed, the window can be moved by step of 64 bytes along the ROM memory in writing the appropriate code in the Write-only Data Window register (DWR register, location C9h).

The DWR register can be addressed like a RAM location in the Data Space at the address C9h, nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to move the 64-byte read-only data window (from the 40h address to 7Fh address of the Data Space) up and down the ROM memory of the MCU in steps of 64 bytes. The effective address of the byte to be read as a data in the ROM memory is obtained by the concatenation of the 6 least significant bits of the register address given in the instruction (as least significant bits) and the content of the DWR register (as most significant bits, see Figure 10). So when addressing location 40h of dataspace, and 0 is loaded in the DWR register, the phisycal addressed location in ROM is 00h. The DWR register is not cleared at reset, therefore it must be written to before the first access to the Data ROM window area.

#### DWR Data ROM Window Register (C9h, Write Only) D7 D6 D5 D4 D3 D2 D1 D0 DWR0 = Data ROM Window 0 DWR1 = Data ROM Window 1 DWR2 = Data ROM Window 2 DWR3 = Data ROM Window 3 DWR4 = Data ROM Window 4 DWR5 = Data ROM Window 5 DWR6 = Data ROM Window 6 Unused

Figure 11. Data ROM Window Register

**D7.** This bit is not used.

DWR6-DWR0. These are the Data ROM Window bits that correspond to the upper bits of the data ROM space.

#### This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

Note: Care is required when handling the DWR register as it is write only. For this reason, it is not allowed to change the DWR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. If it is impossible to avoid the writing of this register in the interrupt service routine, an image of this register must be saved in a RAM location, and each time the program writes to the DWR it must write also to the image register. The image register must be written first, so if an interrupt occurs between the two instructions the DWR is not affected.

Figure 10. Data ROM Window Memory Addressing



#### Data RAM/EEPROM Bank Register (DRBR)

The selection of the bank is made by programming the Data RAM Bank Switch register (DRBR register) located at address CBh of the Data Space. The number of the selected bank is equal to the bit content of the DRBR register. In this way each bank of RAM or EEPROM can be selected 64 bytes at a time. No more than one bank should be set at a time.

The DRBR register can be addressed like a RAM location in the Data Space at the address CBh; nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to select the desired 64-byte RAM/EEPROM bank of the Data Space. The number of the bank has to be loaded in the DRBR register and the instruction has to point to the selected location as if it was in bank 0 (from 00h address to 3Fh address). This register is not cleared during the MCU initialization, therefore it must be written before the first access to the Data Space bank region. Refer to the Data Space description for additional information. The DRBR register is not modified when a interrupt or a subroutine occurs.

| Table 3. | Data R | AM | Bank | Register | Set-up |
|----------|--------|----|------|----------|--------|
|----------|--------|----|------|----------|--------|

| DRBR Value | Selection     |
|------------|---------------|
| 01h        | EEPROM Page 0 |
| 02h        | EEPROM Page 1 |
| 08h        | RAM Page 1    |
| 10h        | RAM Page 2    |



#### Figure 12. Data RAM Bank Register

The table 3 summarizes how to set the data RAM bank register in order to select the various banks or pages.

D7-D5. These bits are not used.

**DRBR4-DRBR3.** Each of these bits, when set, will select one RAM page.

D2. This bit is not used.

**DRBR1-DRBR0.** Each of these bits, when set, will select one EEPROM page.

This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

#### Notes:

Care is required when handling the DRBR register as it is write only. For this reason, it is not allowed to change the DRBR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. If it is impossible to avoid the writing of this register in interrupt service routine, an image of this register must be saved in a RAM location, and each time the program writes to DRBR it must write also to the image register. The image register must be written first, so if an interrupt occurs between the two instructions the DRBR is not affected.

In DRBR Register, *only 1 bit must be set*. Otherwise two or more pages are enabled in parallel, producing errors.



#### **EEPROM Description**

The data space of ST62xx family from 00h to 3Fh is paged as described in Table 4. The ST6240 has 128 bytes of EEPROM located in two pages of 64 bytes (pages 0 and 1).

The EEPROM pages are physically organized in 32 byte modules (2 modules per page) and does not require dedicated instructions to be accessed in reading or writing. The EEPROM is controlled by the EEPROM Control Register (EECTL = DFh). In order to enable access to the EEPROM, bit 6 of this register must be cleared otherwise any access to the EEPROM will be meaningless.

Any EEPROM location can be read just like any other data location, also in terms of access time.

When writing to an EEPROM, the EEPROM is not accessible by the ST62xx. A busy flag can be read to identify the EEPROM status before attempting any access. Writing the EEPROM can work in two modes: Byte Mode (BMODE) and Parallel Mode (PMODE). BMODE is the normal way to use the EEPROM and consists in accessing one byte at a time. PMODE consists in accessing 8 bytes per time.

Readout of the EEPROM is made at the same speed as RAM acces.

D7. Not Used



#### Figure 13. EEPROM Control Register

**E20FF.** *WRITE ONLY.* If this bit is set the EEPROM is disabled (any access will be meaningless) and the power consumption of the EEPROM is reduced to the lowest values.

D5, D4. Reserved, must be set to zero.

**E2PAR1.** *WRITE ONLY.* Once in Parallel Mode, as soon as the user software sets the E2PAR1 bit the parallel writing of the 8 adjacent registers will start. It is internally reset at the end of the programming procedure. Note that less than 8 bytes can be written; after parallel programming the undefined bytes will be unaffected

**E2PAR2.** *WRITE ONLY.* This bit must be set by the user program in order to perform parallel programming (more than one byte at a time). If E2PAR2 is set and the parallel start bit (E2PAR1) is low, up to 8 adjacent bytes can be written at maximum speed, the contents being stored in volatile registers. These 8 adjacent bytes are considered as a row, whose address lines A7, A6, A5, A4, A3 are fixed while A2, A1 and A0 are the changing bits. E2PAR2 is automatically reset at the end of any parallel programming procedure. It can be reset by the user software before starting the programming procedure, leaving the EEPROM registers unchanged.

**E2BUSY.** *READ ONLY.* This bit will be automatically set by the EEPROM control logic when the user program modifies an EEPROM register. The user program must test it before any read or write EEPROM operation; any attempt to access the EEPROM while the busy bit is set will be aborted and the writing procedure in progress completed.

**E2ENA.** WRITE ONLY. This bit MUST be set to one in order to write to any EEPROM register. If the user program attempts to write to the EEPROM when E2ENA = "0", the involved registers will be unaffected and the BS will not be set.

After RESET the content of EECTL register will be 00h.

#### Notes:

The data to write has to be written directly at the address that it will have inside the EEPROM space. There is no buffer memory between the data•RAM and the EEPROM spaces.

When the EEPROM is busy (E2BUSY = "1") EECTL can not be accessed in write mode, it is only possible to read the status of E2BUSY. This implies that as long as the EEPROM is busy, it is not possible to change the status of the EEPROM control register. EECTL bits 4 and 5 are reserved for test purposes, and must never be set to "1".



Table 4. EEPROM Parallel Write Row Structure



Additional Notes on Parallel Mode. If the user wishes to perform parallel programming, the first action should be to set the E2PAR2 bit to one. From this time the EEPROM will be addressed in writing, the ROW address will be latched and it will be possible to change it only at the end of the programming procedure or by resetting E2PAR2 without programming the EEPROM. After the ROW address latching the ST62xx can "see" only one EEPROM row (the selected one) and any attempt to write or read other rows will produce errors. Do not read the EEPROM while E2PAR2 is set.

As soon as E2PAR2 bit is set, the 8 volatile ROW latches are cleared. From this moment the user can load data in the whole ROW or in a subset. Setting E2PAR1 will modify the EEPROM registers corre-

sponding to the ROW latches accessed after E2PAR2. For example, if the software sets E2PAR2 and accesses the EEPROM by writing to addresses 18h, 1Ah, 1Bh and then sets E2PAR1, these three registers will be modified at the same time; the remaining bytes will be unaffected. Note that E2PAR2 is internally reset at the end of the programming procedure. This implies that the user must set E2PAR2 bit between two parallel programming procedures. Note that if the user tries to set E2PAR1 while E2PAR2 is not set there will not be any programming procedure and the E2PAR1 bit will be unaffected. Consequently E2PAR1 bit cannot be set if E2ENA is low. E2PAR1 can be affected by the user to set it, only if E2ENA and E2PAR2 bits are also set to one.



## TEST MODE

For normal operation the TEST pin must be held low. An on-chip  $100k\Omega$  pull-down resistor is internally connected to the TEST pin.

## **INTERRUPTS**

The ST62xx core can manage 4 different maskable interrupt sources, plus one non-maskable interrupt source (top priority level interrupt). Each source is associated with a particular interrupt vector that contains a Jump instruction to the related interrupt service routine. Each vector is located in the Program Space at a particular address.

When a source provides an interrupt request, and the request processing is also enabled by the ST62xx core, then the PC register is loaded with the address of the interrupt vector (i.e. of the Jump instruction). Finally, the PC is loaded with the address of the Jump instruction and the interrupt routine is processed.

The ST6240 microcontroller has nine different interrupt sources associated to different interrupt vectors as described in Table 5.

| Interrupt<br>Source                 | Associated Vector            | Vector<br>Address |  |  |
|-------------------------------------|------------------------------|-------------------|--|--|
| NMI & PSS<br>Pins                   | Interrupt Vector #0<br>(NMI) | (FFCh-FFDh)       |  |  |
| SPI<br>Peripheral                   | Interrupt Vector #1          | (FF6h-FF7h)       |  |  |
| Port A & B<br>Pins                  | Interrupt Vector #2          | (FF4h-FF5h)       |  |  |
| TIMER 1, 2<br>& 32kHz<br>Oscillator | Interrupt Vector #3          | (FF2h-FF3h)       |  |  |
| ADC<br>Peripheral                   | Interrupt Vector #4          |                   |  |  |

#### Table 5. Interrupt Vectors - Sources Relationship

## Interrupt Vectors Description

The ST62xx core includes 5 different interrupt vectors in order to branch to 5 different interrupt routines in the static page of the Program Space:

 The interrupt vector associated with the nonmaskable interrupt source is named interrupt vector #0. It is located at addresses FFCh,FFDh in the Program Space. On ST6240 this vector is associated with the external falling edge sensitive interrupt pin (NMI) and is also connected to the Power Supply Supervisor circuit. The PSS and NMI interrupts are "ORed" together and the discrimination between PSS interrupt and NMI interrupt can be done by reading the interrupt flag (bit 7) of the PSS control register (Address DAh). An on-chip 100k $\Omega$  pull-up resistor is internally connected to the NMI pin.

- The interrupt vector located at the addresses FF6h, FF7h is named interrupt vector #1. It is associated with SPI peripheral and can be programmed by software to generate an interrupt request after the falling edge or low level of the eighth external clock pulse according to the code loaded in the Interrupt Option Register (IOR).
- The interrupt vector located at the addresses FF4h, FF5h is named interrupt vector #2. It is associated with Port A and B pins and can be programmed by software either in the falling edge detection mode or in the rising edge detection mode according to the code loaded in the Interrupt Option Register (IOR).
- The interrupt vector located at the addresses FF2h, FF3h is named interrupt vector #3. It is associated with Timer 1, Timer 2 and the 32kHz Oscillator peripherals. All these interrupts are "ORed" together and are connected to interrupt line #3 of the core. Discrimination among the three interrupts must be made by polling the Status/Control registers of Timer 1 (0D4h), Timer 2 (0D7h) and 32kHz oscillator (0DBh).
- The interrupt vector located at the addresses FF0h, FF1h is named interrupt vector #4. It is associated with the A/D converter peripheral.

All the on-chip peripherals (refer to their descriptions for further details) have an interrupt request flag bit (TMZ for timer, EOC for A/D, etc.), this bit is set to one when the device wants to generate an interrupt request and a mask bit (ETI for timer, EAI for A/D, etc.) that must be set to one to allow the transfer of the flag bit to the Core.

## **Interrupt Priority**

The non-maskable interrupt request has the highest priority and can interrupt any other interrupt routines at any time, nevertheless the four other interrupts cannot interrupt each other. If more than one interrupt request is pending, they are processed by the ST62xx core according to their priority level: vector #1 has the higher priority while vector #4 the lower. The priority of each interrupt source is fixed.



#### Interrupt Option Register

The Interrupt Option Register (IOR register, location C8h) is used to enable/disable the individual interrupt sources and to select the operating mode of the external interrupt inputs. This register can be addressed in the Data Space as RAM location at the address C8h, nevertheless it is a write-only register that cannot be accessed with single-bit operations. The operating modes of the external interrupt inputs associated to interrupt vectors #1 and #2 are selected through bits 5 and 6 of the IOR register.

#### Figure 14. Interrupt Option Register



**D7.** This bit is not used.

**LES.** Level/Edge Selection Bit. When this bit is set to one, the interrupt #1 (SPI) is low level sensitive, when cleared to zero the negative edge sensitive interrupt is selected.

**ESB.** Edge Selection Bit. When this bit is set to one, the interrupt #2 (Port A & B lines) is positive edge sensitive, when cleared to zero the negative edge sensitive interrupt is selected.

**GEN.** Global Enable Interrupt. When this bit is set to one, all the interrupts are enabled. When this bit is cleared to zero all the interrupts (excluding NMI/PSS) are disabled.

This register is cleared on reset.

| GEN    | SET      | Enable all interrupts                         |
|--------|----------|-----------------------------------------------|
|        | CLEARED  | Disable all interrupts                        |
| ESB    | SET      | Rising edge mode on<br>interrupt input #2     |
|        | CLEARED  | Falling edge mode on<br>interrupt input #2    |
| LES    | SET      | Level-sensitive mode on<br>interrupt input #1 |
|        | CLEARED  | Falling edge mode on<br>interrupt input #1    |
| OTHERS | NOT USED |                                               |

#### Table 6. Interrupt Option Register Description

#### **External Interrupts Operating Modes**

The NMI interrupt is associated to the NMI and PSS external pins of the ST6240. The two interrupt requests are "ORed". The highest priority interrupt request will be generated either by a falling edge applied to the NMI pin or when the voltage level applied to the PSS pin goes below the software programmed value. The discrimination between NMI and PSS interrupt can be done by polling the interrupt flag (Bit 7) of the PSS control register (DAh). The NMI interrupt pin signal is latched and is automatically reset by the core at the beginning of the non-maskable interrupt service routine. An on-chip pull-up resistor and a schmitt trigger is available with the NMI pin.

The two interrupt sources associated with the falling/rising edge mode of the external interrupt pins (SPI vector #1, Ports A and B vector #2,) are connected to two internallatches. Each latch is set when a falling/rising edge occurs and is cleared when the associated interrupt routine is started. So, the occurrence of an external interrupt request is stored: a second interrupt, that occurs during the processing of the first one, will be processed as soon as the first one has been finished (if there is not an higher priority interrupt request). If more than one interrupt occurs during the processing of the first one, these other interrupt requests will be lost.

The storage of the interrupt requests is not available in the level sensitive detection mode. To be taken into account, the low level must be present on the interrupt pin when the core samples the line after the execution of the instructions.

During the end of each instruction the core tests the interrupt lines and if there is an interrupt request the nextinstruction is not executed and the related interrupt routine is executed.



Interrupt Procedure. The interrupt procedure is very similar to a call procedure, indeed the user can consider the interrupt as an asynchronous call procedure. As this is an asynchronous event the user does not know about the context and the time at which it occurred. As a result the user should save all the data space registers which will be used inside the interrupt routines. There are separate sets of processor flags for normal, interrupt and non-maskable interrupt modes which are automatically switched and so these do not need to be saved.

The following list summarizes the interrupt procedure:

#### ST62xx actions

- Interrupt detection
- The flags C and Z of the main routine are exchanged with the flags C and Z of the interrupt routine (or the NMI flags)
- The value of the PC is stored in the first level of the stack
- The normal interrupt lines are inhibited (NMI still active)
- First internal latch is cleared
- The related interrupt vector is loaded in the PC.
   User actions
- User selected registers are saved inside the interrupt service routine (normally on a software stack)
- The source of the interrupt is found by polling (if more than one source is associated to the same vector) the interrupt flag of the source.
- Interrupt servicing
- Return from interrupt (RETI)
- ST62xx actions
- Automatically the ST62xx core switches back to the normal flags (or the interrupt flags) and pops the previous PC value from the stack

The interrupt routine begins usually by the identification of the device that has generated the interrupt request (by polling). The user should save the registers which are used inside the interrupt routine (that holds relevant data) into a software stack. After the RETI instruction execution, the core carries out the previous actions and the main routine can continue.

# Figure 15. Interrupt Processing Flow-Chart





#### Interrupt request and mask bits

#### Interrupt Option Register, IOR Location C8h

- GEN. If this bit is set, all the ST62xx interrupts are enabled, if reset all interrupts are disabled (including the NMI).
- ESB. If this bit is set, all the input lines associated to interrupt vector #2 are rising edge sensitive, if reset they are falling edge sensitive.
- LES. If this bit is set, all the inputs lines associated to interrupt vector #1 are low level sensitive, if reset they are falling edge sensitive.

All other bits in this register are not used.

# Timer Peripherals, TSCR1 and TSCR2 registers, locations D4h and D7h

- TMZ. A low-to-high transition indicates that the timer count register has decremented to zero. This means that an interrupt request can be generated in relation to the state of ETI bit.
- ETI. This bit, when set, enables the timer interrupt request.

# A/D Converter Peripheral, ADCR register location D0h

- EOC. This read only bit indicates when a conversion has been completed, by going to one. An interrupt request can be generated in relation to the state of EAI bit.
- EAI. This bit, when set, enables the A/D converter interrupt request.

#### **PSS Peripheral, PSSCR Register location DAh**

- PSSVD. This read only bit indicates when the voltage level applied to the PSS pin goes below the software programmed value. An interrupt request can be generated in relation to the state of PSSEI bit.
- PSSEI. This bit, when set, enables the Power Supply Supervisor interrupt request.

#### 32kHz Oscillator, 320CR register location DBh

- EOSCI. This bit, when set, enables the 32kHz oscillator interrupt request.
- OSCEOC. This read only bit indicates when the 32kHz oscillator has measured a 500ms elapsed time (providing a 32.768kHz quartz crystal is connected to the 32kHz oscillator dedicated pins). An interrupt request can be generated in relation to the state of EOSCI bit.



## Figure 16. ST6240 Interrupt Circuit Diagram



**WARNING.** GEN is the global enable for all interrupts except NMI. If this bit is cleared, the NMI interrupt is accepted when the ST62xx core is in the normal RUN Mode. NMI is not accepted as a restart is disabled. This state can only be finished by a reset (from the Watchdog or an external Reset Signal).

If the ST62xx core is in STOP or WAIT Mode, the

As a consequence the NMI can be masked in STOP and WAIT modes, but not in RUN mode.



# RESET

The ST6240 can be reset in three ways: by the external reset input (RESET) tied low, by power-on reset and by the digital watchdog/timer peripheral.

# **RESET Input**

The RESET pin can be connected to a device of the application board in order to restart the MCU during its operation. The activation of the RESET pin may occur in the RUN, WAIT or STOP mode. This input has to be used to reset the MCU internal state and provide a correct start-up procedure. The pin is active low. The internal reset signal is generated by adding a delay to the external signal. Therefore even short pulses at the RESET pin will be accepted. This feature is valid providing that  $V_{DD}$ has finished its rising phase and the oscillator is correctly running (normal RUN or WAIT modes).

If RESET activation occurs in the RUN or Wait mode, the MCU is configured in the Reset mode for as long as the signal of the RESET pin is low. The processing of the program is stopped (in RUN mode only) and the Input/Outputs are in the Highimpedance state with pull-up resistors switched on. As soon as the level on the RESET pin becomes high, the initialization sequence is executed.

If a RESET pin activation occurs in the STOP mode, the oscillator starts and all the inputs/outputs are configured in the High-impedance state with pull-up resistors switched on for as long as the level on the RESET pin remains low. When the level of the RESET pin becomes high, a delay is generated by the ST62xx core to wait that the oscillator becomes completely stabilized. Then, the initialization sequence is started.

# Power-On Reset (POR)

The function of the POR consists in waking up the MCU during the power-on sequence. At the beginning of this sequence, the MCU is configured in the Reset state: every Input/Output port is configured in the input mode (High-impedance state with pullup) and no instruction is executed. When the power supply voltage becomes sufficient, the oscillator starts to operate, nevertheless the ST62xx core generates a delay to allow the oscillator to be completely stabilized before the execution of the first instruction. The initialization sequence is then executed.

Internal circuitry generates a Reset pulse when  $V_{DD}$  is switched on. In the case of fast rising  $V_{DD}$  (transition time  $\leq 100\mu$ s), this reset pulse starts the internal reset procedure without the need of external components at the RESET pin. In cases of slowly or non monotonouslyrising  $V_{DD}$ , an external reset signal must be provided for a proper reset of the MCU.

For as long as the reset pin is kept at the low level, the processor remains in the reset state. The reset will be released after the voltage at the reset pin reaches the high level.

#### Note:

To have a correct ST62xx start-up, the user should take care that the reset input does not change to the high level before the  $V_{DD}$  level is sufficient to allow MCU operation at the chosen frequency (see recommended operating conditions).

An on-chip counter circuit provides a delay of 2048 oscillator cycles between the detection of the reset high level and the release of the MCU reset.

A proper reset signal for slow rising  $V_{DD}$ , i.e. the required delay between reaching sufficient operating voltage and the reset input changing to a high level, can be generally provided by an external capacitor connected between the RESET pin and  $V_{SS}$ .



#### **RESET** (Continued)

#### Watchdog Reset

The ST6240 provides an on-chip watchdog function in order to provide a graceful recovery from a software upset. If the watchdog register is not refreshed, preventing the end-of-count being reached, an internal circuit pulls down the RESET pin. The MCU will enter the reset state as soon as the voltage at RESET pin reaches the related low level. This also resets the watchdog which subsequently turns off the pull-down and activates the pull-up device at the RESET pin. This causes the positive transition at the RESET pin and terminates the reset state.

## Figure 17. Reset Circuit



## **Application Notes**

An external resistor between V<sub>DD</sub> and reset pin is not required because an internal pull-up device is provided. If the user prefers, for any reason, to add an external pull-up resistor its value must comply with the Rmin value defined in Figure 18. If the value is lower than Rmin, the on-chip watchdog pull-down transistor might not be able to pull-down the reset pin resulting in an external deactivation of the watchdog function.

The POR function operates in a dynamic manner in the way that it brings about the initialization of the MCU when it detects a dynamic rising edge of the V<sub>DD</sub> voltage. The typical detected threshold is about 2 volts, but the actual value of the detected threshold depends on the way in which the V<sub>DD</sub> voltage rises up. The POR device DOES NOT allow the supervision of a static rising or falling edge of the V<sub>DD</sub> voltage.

#### Figure 18. External Reset Resistance





#### **RESET** (Continued)

## Figure 19. Reset & Interrupt Processing Flow-Chart



#### **MCU Initialization Sequence**

When a reset occurs the stack is reset to the program counter, the PC is loaded with the address of the reset vector (located in the program ROM at addresses FFEh & FFFh). A jump instruction to the beginning of the program has to be written into these locations. After a reset the interrupt mask is automatically activated so that the core is in non-maskable interrupt mode to prevent false or ghost interrupts during the restart phase. Therefore the restart routine should be terminated by a RETI instruction to switch to normal mode and enable interrupts. If no pending interrupt is present at the end of the reset routine the ST62xx will continue with the instruction after the RETI; otherwise the pending interrupt will be serviced.





#### Table 7. Reset Configuration

| Input/Outpu t pins                       | Registers                                                                                                                                                                                            |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Mode with pull-up and no interrupt | All cleared but A,X,Y,V,W,data RAM, LCD RAM,<br>DWR (C9), PRPR (CA), DRBR (CB).<br>Timers prescaler and TCR are initialized respectively at<br>7F and FF. Watchdog register DWDR (D8) is set to FEh. |



#### WAIT & STOP MODES

The WAIT and STOP modes have been implemented in the ST62xx core in order to reduce the consumption of the product when the latter has no instruction to execute. These two modes are described in the following paragraphs

#### WAIT Mode

The configuration of the MCU in the WAIT mode occurs as soon as the WAIT instruction is executed. The microcontroller can also be considered as being in a "software frozen" state where the core stops processing the instructions of the routine, the contents of the RAM locations and peripheral registers are saved as long as the power supply voltage is higher than the RAM retention voltage but where the peripherals are still working.

The WAIT mode is used when the user wants to reduce the consumption of the MCU when it is in idle, while not losing count of time or monitoring of external events. The oscillator is not stopped in order to provide a clock signal to the peripherals. The timer counting may be enabled (writing the PSI bit in TSCR register) and the timer interrupt may be also enabled before entering the WAIT mode; this allows the WAIT mode to be left when timer interrupt occurs. The above explanation related to the timers applies also to the A/D converter.

If the exit from the WAIT mode is performed with a general RESET (either from the activation of the external pin or by watchdog reset) the MCU will enter a normal reset procedure as described in the RESET chapter. If an interrupt is generated during WAIT mode the MCU behavior depends on the state of the ST62xx core before the initialization of the WAIT sequence, but also of the kind of the interrupt request that is generated. This case will be described in the following paragraphs. In any case, the ST62xx core does not generate any delay after the occurrence of the interrupt because the oscillator dock is still available.

#### STOP Mode

If the Watchdog is disabled the STOP mode is available. When in STOP mode the MCU is placed in the lowest power consumption mode. In this operating mode the microcontroller can be considered as being "frozen", no instruction is executed, the oscillator is stopped, the contents of the RAM locations and peripheral registers are saved as long as the power supply voltage is higher than the RAM retention voltage, and the ST62xx core waits for the occurrence of an external interrupt request or Reset activation to output from the STOP state.

If the exit from the STOP mode is performed with a general RESET (by the activation of the external pin) the MCU will enter a normal reset procedure as described in the RESET chapter. The case of an interrupt depends on the state of the ST62xx core before the initialization of the STOP sequence and also of the kind of the interrupt request that is generated.

This case will be described in the following paragraphs. In any case, the ST62xx core generates a delay after the occurrence of the interrupt request in order to wait the complete stabilization of the oscillator before the execution of the first instruction.

#### **Exit from WAIT and STOP Modes**

The following paragraphs describe the output procedure of the ST62xx core from WAIT and STOP modes when an interrupt occurs (not a RESET). It must be noted that the restart sequence depends on the original state of the MCU (normal, interrupt or non-maskable interrupt mode) before the start of the WAIT or STOP sequence, but also of the type of the interrupt request that is generated.

**Normal Mode.** If the ST62xx core was in the main routine when the WAIT or STOP instruction has been executed, the ST62xx core outputs from the stop or wait mode as soon as any interrupt occurs; the related interrupt routine is executed and at the end of the interrupt service routine the instruction that follows the STOP or the WAIT instruction is executed if no other interrupts are pending.



#### WAIT & STOP MODES (Continued)

Not Maskable Interrupt Mode. If the STOP or WAIT instruction has been executed during the execution of the non-maskable interrupt routine, the ST62xx core outputs from the stop or wait mode as soon as any interrupt occurs: the instruction that follows the STOP or the WAIT instruction is executed and the ST62xx core is still in the non-maskable interrupt mode even if another interrupt has been generated.

**Normal Interrupt Mode.** If the ST62xx core was in the interrupt mode before the initialization of the STOP or WAIT sequence, it outputs from the stop or wait mode as soon as any interrupt occurs. Nevertheless, two cases have to be considered:

- If the interrupt is a normal interrupt, the interrupt routine in which the WAIT or STOP was entered will be completed with the execution of the instruction that follows the STOP or the WAIT and the ST62xx core is still in the interrupt mode. At the end of this routine pending interrupts will be serviced in accordance to their priority.
- If the interrupt is a non-maskable interrupt, the non-maskable routine is processed at first. Then the routine in which the WAIT or STOP was entered will be completed with the execution of the instruction that follows the STOP or the WAIT and the ST62xx core remains in the normal interrupt mode.

#### Notes :

To reach the lowest power consumption the user software must take care of:

- placing the A/D converter in its power down mode by clearing the PDS bit in the A/D control register before entering the STOP instruction.
- switching off the 32kHz oscillator by clearing the oscillator start/stop bit in the 32kHz oscillator control register.
- putting the EEPROM on-chip memory in standby mode by setting the E2OFF bit in EEPROM Control Register to one.

The LCD Driver peripheral is automatically switched-off by the STOP instruction when the 32kHz oscillator operation is not selected.

When the hardware activated watchdog is selected or the software watchdog enabled, the STOP instruction is deactivated and any attempt to execute the STOP instruction will cause an execution of a WAIT instruction.

If all the interrupt sources are disabled (including NMI if GEN="0"), the restart of the MCU can only be done by a RESET activation. The WAIT and STOP instructions are not executed if an enabled interrupt request is pending.

#### **ON-CHIP CLOCK OSCILLATOR**

The internal oscillator circuit is designed to require a minimum of external components. A crystal, a ceramic resonator, or an external signal (provided to the OSCin pin) may be used to generate a system clock with various stability/cost tradeoffs. The different clock generator options connection methods are shown in Figure 22.

One machine cycle takes 13 oscillator pulses; 12 clock pulses are needed to increment the PC while and additional 13th pulse is needed to stabilize the internal latches during memory addressing. This means that with a clock frequency of 8MHz the machine cycle is 1.625µs.

The crystal oscillator start-up time is a function of many variables: crystal parameters (especially  $R_S$ ), oscillator load capacitance (CL), IC parameters, ambient temperature, supply voltage. It must be observed that the crystal or ceramic leads and circuit connections must be as short as possible. Typical values for CL1, CL2 are 15-22pF for a 4/8MHz crystal. The oscillator output frequency is internally divided by 13 to produce the machine cycle and by 12 to produce the Timer, the Watchdog and the A/D peripheralclock. A machine cycle is the smallest unit needed to execute any operation (i.e., increment the program counter). An instruction may need two, four, or five machine cycles to be executed.

**Figure 21. Crystal Parameters** 





# **ON-CHIP CLOCK OSCILLATOR** (Continued)

#### Figure 22. Oscillator Connection





# **INPUT/OUTPUT PORTS**

The ST6240 microcontroller has 16 Input/Output lines that can be individually programmed either in the input mode or the output mode with the following options that can be selected by software:

- Input without pull-up and without interrupt
- Input with pull-up and with interrupt
- Input with pull-up without interrupt
- Analog inputs (PA0-PA7, PB0-PB3)
- SPI control signals (PB5-PB7)
- Push-pull output
- Standard Open drain output
- 20mA Open drain output (PB4-PB7)

The lines are organized in two ports (port A,B).

Each port occupies 3 registers in the data space. Each bit of these registers is associated with a particular line (for instance, the bits 0 of the Port A Data, Direction and Option registers are associated with the PA0 line of Port A).

The two DATA registers (DRA, DRB), are used to read the voltage level values of the lines programmed in the input mode, or to write the logic value of the signal to be output on the lines configured in the output mode. The port data registers can be read to get the effective logic levels of the pins, but they can be also written by the user software, in conjunction with the related option registers, to select the different input mode options.

Single-bit operations on I/O registers are possible but care is necessary because reading in input mode is done from I/O pins while writing will directly affect the Port data register causing an undesired change of the input configuration.

The two Data Direction registers (DDRA, DDRB) allow the selection of the data direction of each pin (input or output).

The two Option registers (ORA, ORB) are used to select the different port options available both in input and in output mode.

All the I/O registers can be read or written as any other RAM location of the data space, so no extra RAM cell is needed for port data storing and manipulation. During the initialization of the MCU, all the I/O registers are cleared and the input mode with pull-up/no-interrupt is selected on all the pins, thus avoiding pin conflicts.



## Figure 23. I/O Port Block Diagram



#### INPUT/OUTPUT PORTS (Continued)

#### **I/O Pin Programming**

Each pin can be individually programmed as input or output with different input and output configurations.

This is achieved by writing to the relevant bit in the data (DR), data direction register (DDR) and option registers (OR). Table 8 shows all the port configurations that can be selected by user software.

#### **Input Option Description**

**Pull-up, High Impedance Option.** All the input lines can be individually programmed with or without an internal pull-up according to the codes programmed in the OR and DR registers. If the pull-up option is not selected, the input pin is in the high-impedance state.

**Interrupt Option.** All the input lines can be individually connected by software to the interrupt lines of the ST62xx core according to the codes programmed in the OR and DR registers. The pins of Port A and B are "ORed" and are connected to the interrupt associated to the vector #2. The interrupt modes (falling edge sensitive, rising edge sensitive) can be selected by software for each port by programming the IOR register.

**Analog Input Option.** The twelve PA0-PA7, PB0-PB3 pins can be configured to be analog inputs according to the codes programmed in the OR and DR registers. These analog inputs are connected to the on-chip 8-bit Analog to Digital Converter. *ONLY ONE* pin should be programmed as analog input at a time, otherwise the selected inputs will be shorted.

#### Figure 24. I/O Port Data Registers







Figure 26. I/O Port Option Registers



**Note:** For complete coding explanation refer to Table 8.



# **INPUT/OUTPUT PORTS** (Continued) Table 8. I/O Port Options Selection

| DDR | OR DR Mode Option Schematic |   |        |                                                                    |                     |  |
|-----|-----------------------------|---|--------|--------------------------------------------------------------------|---------------------|--|
|     |                             |   |        |                                                                    |                     |  |
| 0   | 0                           | 0 | Input  | Pull-up<br>No interrupt<br>(RESET state)                           | Data in             |  |
| 0   | 0                           | 1 | Input  | No pull-up<br>No interrupt                                         | Data in             |  |
| 0   | 1                           | 0 | Input  | Pull-up<br>Interrupt                                               | Data in             |  |
| 0   | 1                           | 1 | Input  | No pull-up<br>No interrupt<br>PB4-PB7                              | Data in             |  |
|     |                             |   | Input  | Analog input:<br>PA0-PA7<br>PB0-PB3                                | -C ADC              |  |
| 1   | 0                           | х | Output | Open drain: 20mA<br>PB4-PB7<br>Open drain: 5mA<br>PB0-PB3, PA0-PA7 | Data out            |  |
| 1   | 1                           | х | Output | Push-pull                                                          | Data out<br>VR01992 |  |



#### INPUT/OUTPUT PORTS (Continued)

**SPI alternate function Option.** The I/O pins PB5-PB7 are also used by serial peripheral interface SPI. PB5 is connected with the SPI clock input SCL, PB6 is connected with the SPI data input SIN and PB7 is connected with the SPI data output SOUT.

For serial input operation PB5 and PB6 have to be programmed as inputs. For serial output operation PB7 has to be programmed as open-drain output (DDR = "1", OPR = "0"). In this operating mode the output of the SPI shift register instead of the port data register is connected to the port buffer. When PB7 is programmed as push-pull output (DDR = "1", OPR = "1"), the port data register is connected to the port buffer. When the SPI peripheral is not used PB5-PB7 can be used as general purpose I/O lines (provided that PB7 is not selected to be open-drain in output mode).

#### Notes:

Switching the I/O ports from one state to another should be done in a way that no unwanted side effects can happen. The recommended safe transitions are shown below. All other transitions are risky and should be avoided during change of operation mode as it is most likely that there will be an unwanted side-effect such as interrupt generation or two pins shorted together by the analog input lines.

Single bit SET and RES instructions should be used very carefully with Port A and B data registers because these instructions make an implicit read and write back of the whole addressed register byte. In port input mode however data register address reads from input pins, not from data register latches and data register information in input mode is used to set characteristics of the input pin (interrupt, pull-up, analog input), therefore these characteristics may be unintentionally reprogrammed depending on the state of input pins. As general rule is better to use SET and RES instructions on data register only when the whole port is in output mode. If input or mixed configuration is needed it is recommended to keep a copy of the data register in RAM. On this copy it is possible to use single bit instructions, then the copy register could be written into the port data register.

| SET | bit, datacopy |
|-----|---------------|
| LD  | a, datacopy   |

The WAIT and STOP instructions allow the ST62xx to be used in situations where low power consumption is needed. The lowest power consumption is achieved by configuring I/Os in input mode with well-defined logic levels.

The user has to take care not to switch outputs with heavy loads during the conversion of one of the analog inputs in order to avoid any disturbance in the measurement.

Figure 27. I/O Port StateTransition Diagram for Safe Transitions



Note \*. xxx = DDR, OR, DR Bits respectively



#### TIMERS

The ST6240 offers two on-chip Timer peripherals named Timer 1 and Timer 2. Each of these timers consists of an 8-bit counter with a 7-bit programmable prescaler, thus giving a maximum count of 2<sup>15</sup>, and control logic that allows configuring the peripheral in three operating modes. Figure 28 shows the Timer block diagram. Timer 1 only has the external TIMER pin available for the user. The content of the 8-bit counter can be read/written in the Timer/Counter register TCR which is addressed in the data space as a RAM location at addresses D3h or D6h. The state of the 7-bit prescaler can be read in the PSC register at addresses D2h or D5h. The control logic device is managed in the TSCR register (addresses D4h or D7h) as described in the following paragraphs.

The 8-bit counter is decrement by the output (rising edge) coming from the 7-bit prescaler and can be loaded and read under program control. When it decrements to zero then the TMZ (Timer Zero) bit in the TSCR is set to one. If the ETI (Enable Timer Interrupt) bit in the TSCR is also set to one an interrupt request, associated to interrupt vector #3, is generated. The interrupt service routine then would determine which timer reached the end of count by poling the TMZ bits. The Timer interrupt can be used to exit the MCU from the WAIT mode.

The prescaler input can be the oscillator frequency divided by 12 or an external clock at TIMER pin (only Timer 1). The prescaler decrements on the rising edge. Depending on the division factor programmed by PS2, PS1 and PS0 bits in the TSCR, the clock input of the timer/counter register is multiplexed to different sources. On division factor 1, the clock input of the prescaler is also that of timer/counter; on factor 2, bit 0 of prescaler register is connected to the clock input of TCR. This bit changes its state with the half frequency of prescaler clock input. On factor 4, bit 1 of PSC is connected to clock input of TCR, and so on. The prescaler initialize bit (PSI) in the TSCR register must be set to one to allow the prescaler (and hence the counter) to start. If it is cleared to zero then all of the prescaler bits are set to one and the counter is inhibited from counting. The prescaler can be given any value between 0 and 7Fh by writing to addresses D2h or D5h, if bit PSI in the TSCR register is set to one. The tap of the prescaler is selected using the PS2, PS1, PS0 bits in the control register. Figure 29 shows the Timer working principle.



Figure 28. Timer Peripheral Block Diagram



TIMERS (Continued)

#### **Timer Operating Modes**

There are 3 operating modes of the Timer peripheral. They are selected by the bits TOUT and DOUT (see TSCR register). These three modes correspond to the two clock frequencies that can be connected on the 7-bit prescaler (fosc/12 or TIMER pin signal) and to the output mode. For this reason, only Timer 1 has all three modes, while Timer 2, which does not have a dedicated TIMER pin, must be programmed in Output Mode only.

**Clock Input Mode (TOUT = "0", DOUT = "0").** In this mode the TIMER pin is an input and the prescaler is decremented on rising edge. The maximum input frequency that can be applied to the external pin in this mode is 1/8 of the oscillator frequency. This operating mode is not available on Timer 2.

**Gated Mode (TOUT = "0", DOUT = "1").** In this mode the prescaler is decremented by the Timer clock input (oscillator divided by 12) but ONLY when the signal at TIMER pin is held high (giving a pulse width measurement potential). This mode is selected by the TOUT bit in TSCR register cleared to "0" (i.e. as input) and DOUT bit set to "1". This operating mode is not available on Timer 2.

**Output Mode (TOUT = "1", DOUT = data out).** The TIMER pin is connected to the DOUT latch. Therefore the timer prescaler is clocked by the prescaler clock input ( $f_{OSC}/12$ ).

The user can select the desired prescaler division ratio through the PS2, PS1, PS0 bits. When TCR count reaches 0, it sets the TMZ bit in the TSCR. The TMZ bit can be tested under program control to perform a timer function whenever it goes high. The low-to-high TMZ bit transition is used to latch the DOUT bit of the TSCR and pass it to TIMER pin. This operating mode allows external signal generation on the TIMER pin. This is the only operating Mode allowed on Timer 2.

#### **Table 9. Timer Operating Modes**

| ΤΟυτ | DOUT | Timer Pin | Timer Function               |
|------|------|-----------|------------------------------|
| 0    | 0    | Input     | Event Counter <sup>(1)</sup> |
| 0    | 1    | Input     | Input Gated <sup>(1)</sup>   |
| 1    | 0    | Output    | Output                       |
| 1    | 1    | Output    | Output                       |

Note 1. Not allowed on Timer 2



## Figure 29. Timer Working Principle

# TIMERS (Continued)

#### **Timer Interrupt**

When the counter register decrements to zero and the software controlled ETI (Enable Timer Interrupt) bit is set to one then an interrupt request associated to interrupt vector #3 is generated. When the counter decrements to zero also the TMZ bit in the TSCR register is set to one.

Since only one interrupt vector is available for the two timers (ORed also with 32kHz oscillator interrupt), the interrupt service routine should determine from which source the interrupt came by polling the TMZ bits (and the OSCEOC bit of the 32kHz oscillator control register).

#### Notes:

TMZ is set when the counter reaches 00h; however, it may be set by writing 00h in the TCR register or setting bit 7 of the TSCR register. TMZ bit must be cleared by user software when servicing the timer interrupt to avoid undesired interrupts when leaving the interrupt service routine. After reset, the 8-bit counter register is loaded to FFh while the 7-bit prescaler is loaded to 7Fh, and the TSCR register is cleared which means that timer is stopped (PSI="0") and the timer interrupt is disabled.

If the Timer is programmed in output mode, DOUT bit is transferred to the TIMER pin when TMZ is set to one (by software or due to counter decrement). When TMZ is high, the latch is transparent and DOUT is copied to the timer pin. When TMZ goes low, DOUT is latched.

A write to the TCR register will predominate over the 8-bit counter decrement to 00h function, i.e. if a write and a TCR register decrement to 00h occur simultaneously, the write will take precedence, and the TMZ bit is not set until the 8-bit counter reaches 00h again. The values of the TCR and the PSC registers can be read accurately at any time.

## Figure 30. Timer Status Control Register



**TMZ.** Low-to-high transition indicates that the timer count register has decremented to zero. This bit must be cleared by user software before starting with a new count.

**ETI.** This bit, when set, enables the timer interrupt request (vector #3). If ETI="0" the timer interrupt is disabled. If ETI="1" and TMZ="1" an interrupt request is generated.

**TOUT.** When low, this bit selects the input mode for the TIMER pin. When high the output mode is selected.

**DOUT.** Data sent to the timer output when TMZ is set high (output mode only). Input mode selection (input mode only). This bit is meaningless for Timer 2.

**PSI.** Used to initialize the prescaler and inhibit its counting. When PSI="0" the prescaler is set to 7Fh and the counter is inhibited. When PSI="1" the prescaler is enabled to count downwards. As long as PSI="0" both counter and prescaler are not running.

**PS2, PS1, PS0.** These bits select the division ratio of the prescaler register.

**Table 10. Prescaler Division Factors** 

| PS2 | PS1 | PS0 | Divided by | PS2 | PS1 | PS0 | Divided by |
|-----|-----|-----|------------|-----|-----|-----|------------|
| 0   | 0   | 0   | 1          | 1   | 0   | 0   | 16         |
| 0   | 0   | 1   | 2          | 1   | 0   | 1   | 32         |
| 0   | 1   | 0   | 4          | 1   | 1   | 0   | 64         |
| 0   | 1   | 1   | 8          | 1   | 1   | 1   | 128        |

Figure 31. Timer Counter Register



Figure 32. Prescaler Register





#### DIGITAL WATCHDOG

The digital Watchdog of the ST62 device consists of a down counter that can be used to provide a controlled recovery from a software upset.

The ST6240 watchdog has two watchdog options, the software activated watchdog/timer and the hardware activated watchdog function. The user can select one of the two options by connecting the pin WDON to  $V_{DD}$  (software watchdog) or  $V_{SS}$  (hardware watchdog). If the pin is kept non connected, an internal pull-up resistance selects the software watchdog option.

#### Hardware Watchdog Function

The hardware activated digital watchdog function consists of a down counter that is automatically initialized after reset so that this function does not need to be activated by the user program. As the watchdog function is always activated this down counter cannot be used as a timer. The watchdog uses one data space register (DWDR location D8h). The watchdog register is set to FFh on reset and immediately starts to count down, requiring no software start. Similarly the hardware activated watchdog cannot be stopped or delayed by software.

The watchdog time can be programmed using the 6 Most Significant bits in the watchdog register, this gives the possibility to generate a reset in a time

between 3072 to 196608 clock cycles in 64 possible steps (with a clock frequency of 8MHz, this means from 384µs to 24.576ms). The reset is prevented if the register is reloaded with the desired value before bits 2-7 decrement from all zeros to all ones. The check time can be set differently for different routines within the general program. The presence of the hardware watchdog deactivates the STOP instruction and a WAIT instruction is automatically executed instead of a STOP. Bit 1 of the watchdog register (set to one at reset) can be used to generate a software reset if cleared to zero.

#### Software Watchdog

The software activated digital watchdog consists of a down counter that can be used to provide a controlled recovery from a software upset. The watchdog uses one data space register (DWDR location D8h). The watchdog register is set to FEh after reset and the watchdog function is disabled. The watchdog time can be programmed using the 6 Most Significant Bits in the Watchdog register. The check time can be set differently for different routines within the general program.

After a reset the software Watchdog is in the offstate. The watchdog should be activated inside the Reset restart routine by writing a "1" in watchdog timer register bit 0. Bit one of this register must be



Figure 33. Digital Watchdog Block Diagram



#### DIGITAL WATCHDOG (Continued)

set to one before programming bit zero as otherwise a reset will be immediately generated when bit 0 is set. This allows the user to generate a reset by software (bit 0 = "1", bit 1 = "0"). Once bit 0 is set, it can not be cleared by software without generating a Reset. The delay time is defined by programming bits 2-7 of the watchdog register. Bit 7 is the Least Significant Bit while bit 2 is the MSB. This gives the possibility to generate a reset in a time between 3072 to 196608 clock cycles in 64 possible steps: (With a clock frequency of 8MHz this means from 384µs to 24.576ms). The reset is prevented if the register is reloaded with the desired value before bits 2-7 decrement from all zeros to all ones. If the watchdog is active the STOP instruction is deactivated and a WAIT instruction is automatically executed instead of a STOP. If bit 0 of the watchdog register is never set to one then bits 1-7 of the register can be used as a simple 7-bit counter which is decrement every 3072 clock cycles.

#### Figure 35. Watchdog Register



**C.** This is the watchdog activation bit, that, if set to one, will activate the watchdog function. When cleared to zero it allows the use of the counter as a 7-bit timer. If the user selects the hardware function this bit is automatically set on reset and the user cannot change its state. When the software function is selected, this bit is cleared on reset.

**SR.** This bit is set to one during the reset and will generate a software reset if cleared to zero. When C = "0" (watchdog disabled software option) it is the MSB of the 7-bit timer.

**T1-T6.** These are the watchdog counter bits. It should be noted that D7 (T1) is the LSB of the counter and D2 (T6) is the MSB of the counter. These bits are in the opposite order to normal.



DOWN COUNTER

VA00190

#### Figure 34. Watchdog Working Principle



#### **DIGITAL WATCHDOG** (Continued)

#### Application note:

The hardware activation function is very useful when the external circuitry may inject noise on the reset pin, where there is an unstable supply voltage, or RF influence or other similar phenomena.

If the Watchdog software activation is selected and the Watchdog is not used during power-on reset external noise may cause the undesired activation of the Watchdog with a generation of an unexpected reset. To avoid this risk, two additional instructions, that check the state of the watchdog and eventually reset the chip are needed within the first 27 instructions, after the reset. These instructions are:

jrx 0, WD, #+3 ldi WD, 0FDH

These instructions should be executed at the very beginning of the customer program.

If the Watchdog is used (both hardware or software activated), during power-on reset the Watchdog register may be set to a low value, that could give a reset after 28 instructions earliest. To avoid undesired resets, the Watchdog must be set to the desired value within the first 27 instructions, the best is to put at the very beginning.

Alternatively the normal legal state can be checked with the following short routine:

ldi a, OFEH and a, WD cpi a, OFEH jrz #+3 ldi WD, OFDH

This sequence is recommended for security applications, where possible stack confusion error loops must be avoided and the Watchdog must only be refreshed after extensive checks.

#### **8-BIT A/D CONVERTER**

The A/D converter of ST6240 is an 8-bit analog to digital converter with up to 12 analog inputs (as alternate functions of I/O lines PA0-PA7, PB0-PB3) offering 8-bit resolution with total accuracy  $\pm 2$  LSB and a typical conversion time of 70µs (clock frequency of 8MHz).

The A/D peripheral converts the input voltage by a process of successive approximations using a clock frequency derived from the oscillator with a division factor of twelve. With an oscillator clock frequency less than 1.2MHz, the A/D converter accuracy is decreased.

The selection of the pin signal that has to be converted is done by configuring the related I/O line as analog input through the I/O ports option and data registers (refer to I/O ports description for additional information). Only one I/O line must be configured as analog input at a time. The user must avoid the situation in which more than one I/O pin is selected to be analog input to avoid malfunction of the ST62xx.

The ADC uses two registers in the data space: the ADC data conversion register which stores the conversion result and the ADC control register used to program the ADC functions.

A conversion is started by writing a "1" to the Start bit (STA) in the ADC control register. This automatically clears (resets to "0") the End Of Conversion Bit (EOC). When a conversion has been finished this EOC bit is automatically set to "1" in order to flag that conversion is complete and that the data in the ADC data conversion register is valid. Each conversion has to be separately initiated by writing to the STA bit.

The STA bit is continually being scanned so that if the user sets it to "1" while a previous conversion is in progress then a new conversion is started before the previous one has been completed. The



## 8-BIT A/D CONVERTER(Continued)

start bit (STA) is a write only bit, any attempt to read it will show a logical "0".

The A/D converter has a maskable interrupt associated to the end of conversion. This interrupt is associated to the interrupt vector #4 and occurs when the EOC bit is set, i.e. when a conversion is completed. The interrupt is masked using the EAI (interrupt mask) bit in the control register.

The power consumption of the device can be reduced by turning off the ADC peripheral. That is achieved when the PDS bit in the ADC control register is cleared to "0". If PDS="1", the A/D is supplied and enabled for conversion. This bit must be set at least one instruction before the beginning of the conversion to allow the stabilization of the A/D converter. This action is needed also before entering the STOP instruction as the A/D comparator is not automatically disabled by the STOP mode

During reset any conversion in progress is stopped, the control register is reset to all zeros and the A/D interrupt is masked (EAI=0).

| Figure 37. | A/D Con | verter Bloo | ck Diagram |
|------------|---------|-------------|------------|
|------------|---------|-------------|------------|





Figure 36. A/D Converter Control Register

**EAI.** If this bit is set to one the A/D interrupt (vector #4) is enabled, when EAI=0 the interrupt is disabled.

**EOC.** Read Only; This read only bit indicates when a conversion has been completed. This bit is automatically reset to zero when the STA bit is written. If the user is using the interrupt option then this bit can be used as an interrupt pending bit. Data in the data conversion register are valid only when this bit is set to one.

**STA.** *Write Only*; Writing a "1" in this bit will start a conversion on the selected channel and automatically reset to zero the EOC bit. If the bit is set again when a conversion is in progress, the present conversion is stopped and a new one will take place. This bit is write only, any attempt to read it will show a logical zero.

**PDS.** This bit activates the A/D converter if set to 1. Writing a zero into this bit will put the ADC in power down mode (idle mode).

D3-D0. Not used

#### Figure 38. A/D Converter Data Register



**D7-D0.** *Read Only*, These are the conversion result bits; the register is read only and stores the result of the last conversion. The contents of this register are valid only when EOC bit in the ADCR register is set to one (end-of-conversion).



#### 8-BIT A/D CONVERTER(Continued)

#### Notes:

The ST62xx A/D converter does not feature a sample and hold. The analog voltage to be measured should therefore be stable during the conversion time. Variation should not exceed  $\pm 1/2$  LSB for the best accuracy in measurement.

Since the ADC is on the same chip as the microprocessor the user should not switch heavily loaded output signals during conversion if high precision is needed. This is because such switching will affect the supply voltages which are used for comparisons.

A low pass filter can be used at the analog input pins to reduce input voltage variation during the conversion. For true 8 bit conversions the impedance of the analog voltage sources should be less than  $30k\Omega$  while the impedance of the reference voltage should not exceed  $2k\Omega$ .

The accuracy of the conversion depends on the quality of the power supply voltages ( $V_{DD}$  and  $V_{SS}$ ). The user must specially take care of applying regulated reference voltage on the  $V_{DD}$  and  $V_{SS}$  pins (the variation of the power supply voltage must be inferior to 5V/ms).

The converter can resolve the input voltage with an resolution of:

$$\frac{V_{DD} - V_{SS}}{256}$$

So if operating with a supply voltage of 5V the resolution is about 20mV.

The Input voltage (Ain) which has to be converted must be constant for  $1\mu s$  before conversion and remain constant during the conversion.

The resolution of the conversion can be improved if the power supply voltage (VDD) of the microcontroller becomes lower.

In order to optimize the resolution of the conversion, the user can configure the microcontroller in the WAIT mode because this mode allows the minimization of the noise disturbances and the variations of the power supply voltages due to the switching of the outputs. Nevertheless, it must be take care of executing the WAIT instruction as soon as possible after the beginning of the conversion because the execution of the WAIT instruction may provide a small variation of the V<sub>DD</sub> voltage (the negative effect of this variation is minimized at the beginning of the conversion because the latter is less sensitive than the end of the conversion when the less significant bits are determined).

The best configuration from a accuracy point of view is the WAIT mode with the Timer and LCD driver stopped. Indeed, only the ADC peripheral and the oscillator are still working. The MCU has to be wake-up from the WAIT mode by the interrupt of the ADC peripheral at the end of the conversion. It must be noticed that the wake-up of the microcontroller could be done also with the interrupt of the TIMER, but in this case, the Timer is working and some noise could disturb the converter in terms of accuracy.



## POWER SUPPLY SUPERVISOR DEVICE (PSS)

The Power Supply Supervisor device, described in the Figure 39, permits supervising the crossing of the PSS pin voltage (VPSS) through a programmable voltage  $(mxV_{DD}/n)$ , where n and m can be chosen by software. This device includes:

- An internal comparator which is connected to the internal INT line to make an interrupt request to the Core.
- 2 resistive voltage dividers that are, respectively, supplied by the PSS pin and the V<sub>DD</sub> pin. These two voltage dividers are both connected to the two inputs of the internal comparator. They consist of 13 identical resistors. It is possible to select by software 5 voltage rates on the PSS divider (nxVPSS/13) and 4 voltage rates on the V<sub>DD</sub> divider (mxV<sub>DD</sub>/13). The n and m values can be chosen by software. These two voltage dividers are disconnected in STOP mode, and when the PSS device is OFF.
- An internal device that allows the detection with an hysteresis of V<sub>DD</sub>/13.

The PSS device is supplied by an internal connection to  $V_{DD}$  supply. The following paragraphs describe the operating mode of the PSS device and the PSS register that permits control over the PSS device. The PSS device is switched off as soon as the Core executes the STOP instruction, but continues to work in the WAIT mode.

## Figure 40. PSS Device Operating Modes Description





## Figure 39. PSS Device Block Diagram



#### POWER SUPPLY SUPERVISOR(Continued)

#### **PSS Operating Mode Description**

The resistive voltage divider connected to the PSS pin provides the internal comparator with the  $nxV_{PSS}/13$  voltage. The resistive voltage divider connected to the  $V_{DD}$  pin provides the internal comparator with the  $mxV_{DD}/13$  voltage. The n and m values are selected with the PSS register. It must be observed that the n and m values must be selected, taking into consideration the following electrical constraints:

 $0.5V < nxV_{PSS}/13$  at detection  $< V_{DD} - 2V$  $0.5V < mxV_{DD}/13$  at detection  $< V_{DD} - 2V$ we must also have:

 $\frac{m}{n} \ V_{DD} \leq V_{PSS} \leq V_{DD}$ 

The PIF bit is the interrupt request flag of the PSS device. This bit follows PSS comparator output.



#### Figure 41. Typical application using the PSS

#### **POWER SUPPLY SUPERVISOR**(Continued)

#### **PSS Register**

The PSS register permits control over the PSS device. The register can be addressed in the data space as a RAM location at DAh. This register is cleared after Reset.





**PIF.** This bit is the interrupt flag. This bit is set (resp. cleared) as soon as the equality between nxVPSS and  $(m+1)xV_{DD}/13$  (resp. mxV\_DD/13) occurs.

**PEI.** This bit is the authorization bit of the interrupt request:

- If PEI is set, the interrupt request can reach the Core.
- If PEI is cleared, the interrupt request cannot reach the Core.

**PDV1, PDV0.** The PDV1/0 bits are used to select the rate of division of the  $V_{DD}$  voltage (mxV<sub>DD</sub>/13 or (m+1)xV<sub>DD</sub>/13, according to the hysteresis).

| PDV1 | PDV0 | mxV <sub>DD</sub> /13 | (m+1)xV <sub>DD</sub> /13 |
|------|------|-----------------------|---------------------------|
| 0    | 0    | 3xV <sub>DD</sub> /13 | 4xV <sub>DD</sub> /13     |
| 0    | 1    | 5xV <sub>DD</sub> /13 | 6xV <sub>DD</sub> /13     |
| 1    | 0    | 6xV <sub>DD</sub> /13 | 7xV <sub>DD</sub> /13     |
| 1    | 1    | 7xV <sub>DD</sub> /13 | 8xV <sub>DD</sub> /13     |

**PDR2, PDR1, PDR0.** The PDR2/1/0 bits are used to inhibit the PSS device and to select the division rate of the PSS voltage (nxVPSS/13).

The PSS comparator output is valid 8 cycle times after the programming of the PDR2/1/0 bits. It is forced to zero in the meantime.

| PDR2                                    | PDR1        | PDR0        | PSS<br>State         | nxVPSS/13                      |
|-----------------------------------------|-------------|-------------|----------------------|--------------------------------|
| 000000000000000000000000000000000000000 | 0<br>0<br>1 | 0<br>1<br>0 | IDLE<br>BUSY<br>BUSY | 4xVPSS/13<br>5xVPSS/13         |
| 0<br>1<br>1                             | 1<br>0<br>0 | 1<br>0<br>1 | BUSY<br>BUSY<br>BUSY | 6xVPSS/13<br>7xVPSS/13<br>VPSS |



#### 32kHz STAND-BY OSCILLATOR

The 32kHz stand-by oscillator allows the ST6240 to generate real time interrupts and to supply the clock to the LCD driver. This enables the ST6240 to provide real time functions with the LCD display capability and lower power consumption. Figure 43 shows the 32kHz oscillator block diagram.

A 32.768kHz quartz crystal must be connected to the OSC32in and OSC32out pins to perform the real time clock operation. Two external capacitors of 15-22pF each must be connected between the oscillator pins and ground. The 32kHz oscillator is managed by the dedicated status/control register located at address 0DBh.

When the 32kHz stand-by oscillator is stopped (bit 5 of the Status/Control register cleared) the divider chain is supplied with a clock signal synchronous with machine cycle ( $f_{OSC}/13$ ), this produces an interrupt request every  $13x2^{14}$  clock cycle (i.e. 26.624ms) with an 8MHz quartz crystal.

When the 32kHz stand-by oscillator is enabled (bit 5 of the Status/Control register set to one) the divider chain is directly supplied with the 32kHz oscillator clock. The 32kHz clock from the standby oscillator can also be used as the LCD clock. This allows operation of the LCD in STOP mode. The interrupt output of the 32kHz oscillator peripheral generates an interrupt request every half second (500ms). This can be used to perform a real time clock function when the MCU is in STOP mode.

This interrupt signal is "ORed" with the interrupt request signals of the two on-chip timers and connected to the low level sensitive interrupt input associated to the interrupt vector #3 (FF2h, FF3h). The interrupt request has to be cleared by user software before leaving the interrupt service routine. Discrimination between the three interrupt sources is made by polling the Status/Control registers of Timer 1 (D4h), Timer 2 (D7h) and 32kHz oscillator (DBh).





### 32kHz STAND-BY OSCILLATOR (Continued)

32kHz Oscillator Status/Control Register

Figure 44. 32kHz Oscillator Register



**EOSCI.** Enable Oscillator Interrupt. This bit, when set, enables the 32kHz oscillator interrupt request. **OSCEOC.** Oscillator Interrupt Flag. This bit indi-

#### **SERIAL PERIPHERAL INTERFACE (SPI)**

The ST6240 SPI is an optimized serial synchronous interface that supports a wide range of industry standard SPI specifications. The ST6240 SPI is controlled by small and simple user software to perform serial data exchange. The serial shift clock can be implemented either by software (using the bit-set and bit-reset instructions), with the on-chip Timer 1 by externally connecting the SPI clock pin to the timer pin or by directly applying an external clock to the SPI.

The peripheral is composed by an 8-bit Data/shift Register (address DDh) and a 4-bit binary counter. The SCL, Sin and Sout SPI data and clock signals are connected to the PB5, PB6 and PB7 I/O lines. With the 3 I/O pins, the SPI can operate in the following operating modes: Software SPI, S-BUS, I<sup>2</sup>C-bus and as a standard serial I/O (clock, data, enable). An interrupt request can be generated

#### Figure 45. SPI Data/Shift Register



cates when the 32kHz oscillator has measured a 500ms elapsed time (providing a 32.768kHz quartz crystal is connected to the 32kHz oscillator dedicated pins). An interrupt request can be generated in relation to the state of EOSCI bit. This bit must be cleared by the user program before leaving the interrupt service routine.

**START/STOP.** Oscillator Start/Stop bit. This bit, when set, enables the 32kHz stand-by oscillator and the free running divider chain is supplied by the 32kHz oscillator signal. When this bit is cleared to zero the divider chain is supplied with the clock signal from the LCD Controller.

This register is cleared during reset.

#### Note:

To achieve minimum power consumption in STOP mode (no system clock), the stand-by oscillator must be switched off (real time function not available) by clearing the Start/Stop bit in the oscillator status/control register.

after eight clock pulses. Figure 46 shows the SPI block diagram.

The PB5/SCL line clocks, on the falling edge, the shift register and the counter. To allow SPI operation the PA5/SCL must be programmed as input, an external clock supplied to this pin will drive the SPI peripheral (slave mode).

If PB5/SCL is programmed as output, a clock signal can be generated by software, setting and resetting the port line by software (master mode).

The SCL clock signal is the shift clock for the SPI data/shift register. The PB6/Sin pin is the serial shift input and PA7/Sout is the serial shift output. These two lines can be tied together to implement two wires protocols (I<sup>2</sup>C-bus, etc). When data is serialized, the MSB is the first bit. PA6/Sin has to be programmed as input. For serial output operation PB7/Sout has to be programmed as open-drain output.

After 8 clock pulses (D7..D0) the output  $\overline{Q4}$  of the 4-bit binary counter becomes low, disabling the clock from the counter and the data/shift register. Q4 enables the clock to generate an interrupt on the 8th clock falling edge as long as no reset of the counter (processor write into the 8-bit data/shift register) takes place. After a processor reset the interrupt is disabled. The interrupt is active when writing data in the shift register (DDh) and desactivated when writing any data in the register SPI Interrupt Disable (C2h).



### SERIAL PERIPHERAL INTERFACE (Continued)

The generation of an interrupt to the Core provides information that new data is available (input mode) or that transmission is completed (output mode), allowing the Core to generate an acknowledge on the 9th clock pulse (I<sup>2</sup>C-bus).

Since the SPI interrupt is connected to interrupt #1, the falling edge interrupt option should be selected by clearing to zero bit 6 of the Interrupt Option Register (IOR, C8h).

After power on reset, or after writing the data/shift register, the counter is reset to zero and the clock is enabled. In this condition the data shift register is ready for reception. No start condition has to be detected. Through the user software the Core may pull down the Sin line (Acknowledge) and slow down the SCL, as long as it is needed to carry out data from the shift register.

#### <sup>12</sup>C-bus Master-Slave, Receiver-Transmitter

When pins Sin and Sout are externally connected togetherit is possible to use the SPI as a receiver as well as a transmitter. With a simple software routine (by using bit-set and bit-reset on I/O line) a clock can be generated allowing I<sup>2</sup>C-bus to work in master mode.

When implementing an  $l^2$ C-bus protocol, the start condition can be detected by setting the processor into a "wait for start" condition by simply enabling the interrupt of the PA6/Sin I/O port. This frees the processor from polling the Sin and SCL lines. After the transmission/reception the processor has to poll for the STOP condition. In slave mode the user software can slow down the SCL clock frequency by simply putting the SCL I/O line in output open-drain mode and writing a zero into the corresponding data register bit.

As it is possible to directly read the Sin pin directly through the port register, the software can detect a difference between internal data and external data (master mode). Similar condition can be applied to the clock.

The typical speed of transmission in  $I^2C$  master or slave mode is in the range of 10kHz.

#### Three (Four) Wire Serial Bus

It is possible to use a single general purpose I/O pin (with the corresponding interrupt enabled) as a "chip enable" pin. SCL acts as active or passive clock pin, Sin as data in and Sout as data out (four wire bus). Sin and Sout can be connected together externally to implement three wire bus.

#### Note:

When the SPI is not used, the three I/O lines (Sin, SCL, Sout) can be used as normal I/O, with the following limitation: bit Sout cannot be used in open drain mode as this enables the shift register output to the port.

It is recommended, in order to avoid spurious interrupts from the SPI, to disable the SPI interrupt (the default state after reset) i.e. no write must be made to the 8-bit shift register (DDh). An explicit interrupt disable may be made in software by a dummy write to address C2h.



## Figure 46. SPI Block Diagram



#### LCD CONTROLLER-DRIVER

The ST6240 LCD driver consists of a LCD control logic, a programmable prescaler, a 24 bytes wide dedicated LCD RAM, 45 segment and 4 common outputs. This allows a direct driving of up to 180 LCD segments.

The LCD driver is managed by the LCD Mode/Control register located at data RAM address DCh. Different display modes (1/1 duty, 1/2 duty, 1/3 duty and 1/4 duty) are available to cover a wide range of application requirements. The multiplexing display modes are software selectable by programming bits 6 and 7 of the LCD control register. Bits 0-5 are used to select the LCD drive and frame frequency (in relation to the system clock) and to switch off all segments. The LCD Driver can also be supplied by the 32kHz real-time oscillator allowing working in low power conditions and performing real time clock operation.

According to the data in the LCD RAM, the segment and the common drivers generate the segment and common signals which can directly drive an LCD panel.

The LCD control logic reads automatically the data from the LCD RAM independently and without interruption of the processor. The part of the LCD RAM that is not used for displaying can be used as normal data memory.

The scale factor of the clock prescaler can be fixed by software, therefore different frame frequencies can be defined.

The ST6240 oscillator should operate with a 1.0486, 2.0972, 4.1943, 8.3886MHz frequency quartz crystal. This allows the associated division rates to achieve an internal reference frequency of 32.768kHz. The different division rates can be achieved by programming bits 3, 4, 5 in the LCD control register (see Table 14). It is not recommended to select an internal frequency lower than 32.768kHz as the clock supervisor circuit may switch off the LCD peripheral if the lower frequency is detected.

When the display is turned off, all segment and common outputs are switched to ground, causing all the segments to be switched off regardless of the contents of the LCD RAM.

When the Stand-by oscillator function is selected, the 32kHz stand-by oscillator is selected as clock source for the LCD.

To avoid incomplete frames of the LCD, the mode control bits do not immediately influence the LCD controller when the LCD control register is written. They are stored in a temporary register and change the LCD function only at the end of the frame. Special care must be taken when entering the STOP mode. After switching the LCD clock source from the main oscillator to the 32kHz standby oscillator it must be guaranteed that enough clock pulses are delivered to complete the current frame before entering the STOP mode. Otherwise the LCD function will not be changed and the LCD will be switched OFF after entering the STOP mode. Different LCD frame frequencies for each display mode are selected by bits in the LCD control register (see Table 15).

#### Figure 47. LCD Mode Control Register



**DS0, DS1.** Duty cycle select bits. These bits select the number of common backplanes used by the LCD control. This allows different multiplexing conditions.

**HF0, HF1, HF2.** These bits allow the LCD controller to be supplied with the correct frequency when different high main oscillator frequencies are selected as system clock. Table 14 shows the set-up for different clock crystals.

**LF0, LF1, LF2.** These bits control the LCD base operational frequency of the LCD common lines. Table 15 shows the set-up to select the different frequencies while table 16 shows the correspond-

Table 13. Duty Cycle Selection

| DS1 | DS0 | Display<br>Mode | Active<br>Blackplanes | Max.<br>Number of<br>Segments<br>Driven |
|-----|-----|-----------------|-----------------------|-----------------------------------------|
| 0   | 0   | 1/4 duty        | COM1, 2, 3, 4         | 180                                     |
| 0   | 1   | 1/1 duty        | COM1                  | 45                                      |
| 1   | 0   | 1/2 duty        | COM1, 2               | 90                                      |
| 1   | 1   | 1/3 duty        | COM1, 2, 3            | 135                                     |



## Table 14. High Frequency Select Bits

| HF2 | HF1 | HF0 | Function                  | fosc      |
|-----|-----|-----|---------------------------|-----------|
| 0   | 0   | 0   | Display off               |           |
| 0   | 0   | 1   | for stand-by Oscillator   | 32.768kHz |
| 0   | 1   | 0   | NOT TO BE USED            |           |
| 0   | 1   | 1   | ÷ 32 for main oscillator  | 1.048MHz  |
| 1   | 0   | 0   | ÷ 64 for main oscillator  | 2.097MHz  |
| 1   | 0   | 1   | ÷ 128 for main oscillator | 4.194MHz  |
| 1   | 1   | 0   | ÷ 256 for main oscillator | 8.388MHz  |
| 1   | 1   | 1   | NOT TO BE USED            |           |

Notes :

1. The usage  $f_{osc}$  values different from those defined in this table cause the LCD to operate at a reference frequency different from 32.768kHz.

2. It is not recommended to select an internal frequency lower than 32.768kHz as the clock supervisor circuit may switch off the LCD peripheral if lower frequency is detected.

| LF2 | LF1 | LF0 | f <sub>LCD</sub> (Hz) |
|-----|-----|-----|-----------------------|
| 0   | 0   | 0   | 64                    |
| 0   | 0   | 1   | 85                    |
| 0   | 1   | 0   | 128                   |
| 0   | 1   | 1   | 171                   |
| 1   | 0   | 0   | 256                   |
| 1   | 0   | 1   | 341                   |
| 1   | 1   | 0   | 512                   |
| 1   | 1   | 1   | Not to be Used        |

#### Table 15. LCD Frequency Select Bits

ing frame values with the different multiplexing conditions.

According to the selected LCD drive frequency fLCD the frame frequencies come out as shown in Table 16.

The Figure 54 illustrates the waveforms of the different duty signals.

#### Table 16. Available Frame Frequencies for LCD

| f <sub>LCD</sub> | Frame Frequency f <sub>F</sub> (Hz) |     |          |          |  |  |  |  |
|------------------|-------------------------------------|-----|----------|----------|--|--|--|--|
| (Hz)             | 1/1 duty 1/2 duty 1/3 du            |     | 1/3 duty | 1/4 duty |  |  |  |  |
| 512              | 512                                 | 256 | 171      | 128      |  |  |  |  |
| 341              | 341                                 | 171 | 114      | 85       |  |  |  |  |
| 256              | 256                                 | 128 | 85       | 64       |  |  |  |  |
| 171              | 171                                 | 85  | 57       | 43       |  |  |  |  |
| 128              | 128                                 | 64  | 43       | 32       |  |  |  |  |
| 85               | 85                                  | 43  | 28       | 21       |  |  |  |  |
| 64               | 64                                  | 32  | 21       | 16       |  |  |  |  |

The value of the VLCD voltage can be chosen independently from  $V_{DD}$  according to the display requirements. The intermediate VLCD levels 2/3 VLCD, 1/3 VLCD and 1/2 VLCD are generated by an internal resistor network as shown in Figures 52 and 53. The half VLCD level for 1/2 duty cycle is obtained by the external connection of VLCD1/3 and VLCD2/3 pins. All intermediate VLCD levels are connected to pins to enable external capacitive buffering or resistive shunting.



The internal resistive divider network is realized with two parallel dividers. One has high resistivity, the other one low resistivity. The high resistive divider (R<sub>H</sub>) is permanently switched on during the LCD operation. The low resistive divider (R<sub>L</sub>) is only switched on for a short period of time when the levels of common lines and segment lines are changed. This method combines low source impedance for fast switching of the LCD pixels with high source impedance for low power consumption. Fig. 48 shows the typical current into V<sub>LCD</sub> pin in dependency of the display voltage V<sub>LCD</sub>.

## Figure 48. Typical Current Consumption on VLCD Pin (25°C, no load, fLCD= 512 Hz, mux=1/3-1/4)



the display is switched off (by program or reset) the internal resistor network is also switched off to achieve minimum power consumption. The low resistivity divider is active at each edge of  $f_{LCD}$  during 8 clock cycles of  $F_{32kHz}$ .

The internal resistor network is implemented with resistive transistor elements to achieve high precision. For display voltages  $V_{LCD} < 4.5V$  the resistivity of the divider may be too high for some applications (especially using 1/3 or 1/4 duty display mode). In that case an external resistive divider must be used to achieve the desired resistivity.

## Figure 49. Typical Chronogram of Activation of the $V_{LCD}$ Divider Network





Typical External resistances values are in the range of 100 k $\Omega$  to 150 k $\Omega$ . External capacitances in the range of 10 to 47 nF can be added to V<sub>LCD</sub> 2/3 and V<sub>LCD</sub> 1/3 pins and to V<sub>LCD</sub> if the V<sub>LCD</sub> connection is highly impedant.

When the program is switched off (by program or reset) the internal resistor network is also switched off to achieve minimum power consumption.

## Figure 50. Typical Network to connect to $V_{LCD}$ pins if $V_{LCD} \leq 4.5V$



#### Figure 51. Generation of the 32kHz clock



#### Figure 52. Bias Config for 1/2 Duty



## Figure 53. Bias Configuration for 1/1, 1/3 and 1/4 Duty Operation of LCD





#### Address Mapping of the Display Segments.

The LCD RAM is located in the ST6240 data space from addresses E0h to F7h. The LCD forms a matrix of 45 segment lines (rows) and up to 4 common lines (columns). Each bit of the LCD RAM is mapped to one element of the LCD matrix, as described in Figure 55. If a bit is set, the corresponding LCD segment is switched on; if it is reset, the segment is switched off. The segments outputs S1, S2 and S3 are not connected to any pin.

When multiplex rates lower than 1/4 are selected, the unused LCD RAM is free for general use. In the 1/2 duty mode, for instance, half of the LCD RAM is available for storing general purpose data. The address range from F8h to FEh can be used as general purpose data RAM, but not for displaying data (it is reserved for future LCD expansion).

After a reset, the LCD RAM is not initializated and contains arbitrary information. As the LCD control register is reset, the LCD is completely switched off.



#### Figure 54. Common Signal Waveforms



#### Figure 55. Addressing Map of the LCD RAM

| Data RAM<br>Address | MSB |                                                                  |     |     |     |     |     | LSB |        |
|---------------------|-----|------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--------|
| E0                  | S8  | S7                                                               | S6  | S5  | S4  | NA  | NA  | NA  |        |
| E1                  | S16 | S15                                                              | S14 | S13 | S12 | S11 | S10 | S9  |        |
| E2                  | S24 | S23                                                              | S22 | S21 | S20 | S19 | S18 | S17 | 0.014  |
| E3                  | S32 | S31                                                              | S30 | S29 | S28 | S27 | S26 | S25 | COM1   |
| E4                  | S40 | S39                                                              | S38 | S37 | S36 | S35 | S34 | S33 |        |
| E5                  | S48 | S47                                                              | S46 | S45 | S44 | S43 | S42 | S41 |        |
| E6                  | S8  | S7                                                               | S6  | S5  | S4  | NA  | NA  | NA  |        |
| E7                  | S16 | S15                                                              | S14 | S13 | S12 | S11 | S10 | S9  |        |
| E8                  | S24 | S23                                                              | S22 | S21 | S20 | S19 | S18 | S17 | COM2   |
| E9                  | S32 | S31                                                              | S30 | S29 | S28 | S27 | S26 | S25 | COM2   |
| EA                  | S40 | S39                                                              | S38 | S37 | S36 | S35 | S34 | S33 |        |
| EB                  | S48 | S47                                                              | S46 | S45 | S44 | S43 | S42 | S41 |        |
| EC                  | S8  | S7                                                               | S6  | S5  | S4  | NA  | NA  | NA  |        |
| ED                  | S16 | S15                                                              | S14 | S13 | S12 | S11 | S10 | S9  |        |
| EE                  | S24 | S23                                                              | S22 | S21 | S20 | S19 | S18 | S17 | COM3   |
| EF                  | S32 | S31                                                              | S30 | S29 | S28 | S27 | S26 | S25 | CONS   |
| F0                  | S40 | S39                                                              | S38 | S37 | S36 | S35 | S34 | S33 |        |
| F1                  | S48 | S47                                                              | S46 | S45 | S44 | S43 | S42 | S41 |        |
| F2                  | S8  | S7                                                               | S6  | S5  | S4  | NA  | NA  | NA  |        |
| F3                  | S16 | S15                                                              | S14 | S13 | S12 | S11 | S10 | S9  |        |
| F4                  | S24 | S23                                                              | S22 | S21 | S20 | S19 | S18 | S17 | COM4   |
| F5                  | S32 | S31                                                              | S30 | S29 | S28 | S27 | S26 | S25 | CO1V14 |
| F6                  | S40 | S39                                                              | S38 | S37 | S36 | S35 | S34 | S33 |        |
| F7                  | S48 | S47                                                              | S46 | S45 | S44 | S43 | S42 | S41 |        |
| F8 - FE             |     | TO BE USED AS GENERAL PURPOSE DATA RAM<br>(NOT FOR DISPLAY DATA) |     |     |     |     |     |     |        |

#### Notes:

In STOP mode no clock is available for the LCD controller from the main oscillator. If the 32kHz oscillator is activated the LCD can also operate in STOP mode. If the stand-by oscillator is not active, the LCD controller is switched off when STOP instruction is executed; this mode has to be selected to reach the lowest power consumption.

A missing LCD clock (no oscillator active, broken crystal, etc.) is detected by a clock supervisor circuit that switches all the segments and common lines to ground to avoid destructive DC levels at the LCD.

The LCD function change is only effective at the end of a frame. For this reason special care has to be taken when entering the STOP mode. After switching the LCD clock source from the main oscillator to the 32kHz stand-by oscillator it must be guaranteed that enough clock pulses are delivered to complete the current frame before entering the STOP mode. Otherwise the LCD function will not be changed and the LCD is switched off after entering the STOP mode.

The RAM address F8-FEh are not used for LCD display purposes. So they are available as 7 additional Data RAM registers.



#### SOFTWARE DESCRIPTION

The ST62xx software has been designed to fully use the hardware in the most efficient way possible while keeping byte usage to a minimum, in short to provide byte efficient programming capability. The ST62xx core has the ability to set or clear any register or RAM location bit of the Data space with a single instruction. Furthermore, the program may branch to a selected address depending on the status of any bit of the Data space. The carry bit is stored with the value of the bit when the SET or RES instruction is processed.

#### Addressing Modes

The ST62xx core has nine addressing modes which are described in the following paragraphs. The ST62xx core uses three different address spaces: Program space, Data space, and Stack space. Program space contains the instructions which are to be executed, plus the data for immediate mode instructions. Data space contains the Accumulator, the X,Y,V and W registers, peripheral and Input/Output registers, the RAM locations and Data ROM locations (for storage of tables and constants). Stack space contains six 12-bit RAM cells used to stack the return addresses for subroutines and interrupts.

**Immediate.** In the immediate addressing mode, the operand of the instruction follows the opcode location. As the operand is a ROM byte, the immediate addressing mode is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter).

**Direct.** In the direct addressing mode, the address of the byte that is processed by the instruction is stored in the location that follows the opcode. Direct addressing allows the user to directly address the 256 bytes in Data Space memory with a single two-byte instruction.

**Short Direct.** The core can address the four RAM registers X,Y,V,W (locations 80h, 81h, 82h, 83h) in the short-direct addressing mode . In this case, the instruction is only one byte and the selection of the location to be processed is contained in the op-code. Short direct addressing is a subset of the direct addressing mode. (Note that 80h and 81h are also indirect registers).

**Extended.** In the extended addressing mode, the 12-bit address needed to define the instruction is obtained by concatenating the four less significant bits of the opcode with the byte following the opcode. The instructions (JP, CALL) that use the extended addressing mode are able to branch to any address of the 4K bytes Program space.

An extended addressing mode instruction is twobyte long. Program Counter Relative. The relative addressing mode is only used in conditional branch instructions. The instruction is used to perform a test and, if the condition is true, a branch with a span of -15 to +16 locations around the address of the relative instruction. If the condition is not true, the instruction that follows the relative instruction is executed. The relative addressing mode instruction is onebyte long. The opcode is obtained in adding the three most significant bits that characterize the kind of the test, one bit that determines whether the branch is a forward (when it is 0) or backward (when it is 1) branch and the four less significant bits that give the span of the branch (0h to Fh) that must be added or subtracted to the address of the relative instruction to obtain the address of the branch.

**Bit Direct.** In the bit direct addressing mode, the bit to be set or cleared is part of the opcode, and the byte following the opcode points to the address of the byte in which the specified bit must be set or cleared. Thus, any bit in the 256 locations of Data space memory can be set or cleared.

**Bit Test & Branch.** The bit test and branch addressing mode is a combination of direct addressing and relative addressing. The bit test and branch instruction is three-byte long. The bit identification and the tested condition are included in the opcode byte. The address of the byte to be tested follows immediately the opcode in the Program space. The third byte is the jump displacement, which is in the range of -126 to +129. This displacement can be determined using a label, which is converted by the assembler.

**Indirect.** In the indirect addressing mode, the byte processed by the register-indirect instruction is at the address pointed by the content of one of the indirect registers, X or Y (80h,81h). The indirect register is selected by the bit 4 of the opcode. A register indirect instruction is one byte long.

**Inherent.** In the inherent addressing mode, all the information necessary to execute the instruction is contained in the opcode. These instructions are one byte long.



#### **Instruction Set**

The ST62xx core has a set of 40 basic instructions. When these instructions are combined with nine addressing modes, 244 usable opcodes can be obtained. They can be divided into six different types:load/store, arithmetic/logic, conditional branch, control instructions, jump/call, bit manipulation. The following paragraphs describe the different types.

All the instructions within a given type are presented in individual tables.

Load & Store. These instructions use one, two or three bytes in relation with the addressing mode. One operand is the Accumulator for LOAD and the other operand is obtained from data memory using one of the addressing modes.

For Load Immediate one operand can be any of the 256 data space bytes while the other is always immediate data.

| Instruction |                 | Dutes | Cycles | Fla | ags |
|-------------|-----------------|-------|--------|-----|-----|
| Instruction | Addressing Mode | Bytes | Cycles | Z   | С   |
|             |                 |       |        |     |     |
| LD A, X     | Short Direct    | 1     | 4      | Δ   | *   |
| LD A, Y     | Short Direct    | 1     | 4      | Δ   | *   |
| LD A, V     | Short Direct    | 1     | 4      | Δ   | *   |
| LD A, W     | Short Direct    | 1     | 4      | Δ   | *   |
| LD X, A     | Short Direct    | 1     | 4      | Δ   | *   |
| LD Y, A     | Short Direct    | 1     | 4      | Δ   | *   |
| LD V, A     | Short Direct    | 1     | 4      | Δ   | *   |
| LD W, A     | Short Direct    | 1     | 4      | Δ   | *   |
| LD A, rr    | Direct          | 2     | 4      | Δ   | *   |
| LD rr, A    | Direct          | 2     | 4      | Δ   | *   |
| LD A, (X)   | Indirect        | 1     | 4      | Δ   | *   |
| LD A, (Y)   | Indirect        | 1     | 4      | Δ   | *   |
| LD (X), A   | Indirect        | 1     | 4      | Δ   | *   |
| LD (Y), A   | Indirect        | 1     | 4      | Δ   | *   |
|             |                 |       |        |     |     |
|             |                 |       |        |     |     |
| LDI A, #N   | Immediate       | 2     | 4      | Δ   | *   |
| LDI rr, #N  | Immediate       | 3     | 4      | *   | *   |
|             |                 |       |        |     |     |

#### Table 17. Load & Store Instructions

Notes:

X,Y.Indirect Register Pointers, V & W Short Direct Registers

#. Immediate data (stored in ROM memory)

rr. Data space register ∆ . Affected \*. Not ^#

Not Affected



Arithmetic and Logic. These instructions are used to perform the arithmetic calculations and logic operations. In AND, ADD, CP, SUB instructions one operand is always the accumulator while the other can be either a data space memory content or an immediate value in relation with the addressing mode. In CLR, DEC, INC instructions the operand can be any of the 256 data space addresses. In COM, RLC, SLA the operand is always the accumulator.

| Instruction        | A dalama a inan Marala | Dutas  | Qualas | Fla             | igs      |
|--------------------|------------------------|--------|--------|-----------------|----------|
| Instruction        | Addressing Mode        | Bytes  | Cycles | Z               | С        |
| ADD A, (X)         | Indirect               | 1      | 4      | Δ               | Δ        |
| ADD A, (Y)         | Indirect               | 1      | 4      | Δ               | Δ        |
| ADD A, rr          | Direct                 | 2      | 4      | Δ               | Δ        |
| ADDI A, #N         | Immediate              | 2      | 4      | Δ               | Δ        |
| AND A, (X)         | Indirect               | 1      | 4      | Δ               | *        |
| AND A, (Y)         | Indirect               | 1      | 4      | Δ               | *        |
| AND A, rr          | Direct                 | 2      | 4      | Δ               | *        |
| ANDI A, #N         | Immediate              | 2      | 4      | Δ               | *        |
| CLR A              | Short Direct           | 2      | 4      | Δ               | Δ        |
| CLR rr             | Direct                 | 3      | 4      | *               | *        |
| COM A              | Inherent               | 1      | 4      | Δ               | Δ        |
| CP A, (X)          | Indirect               | 1      | 4      | Δ               | Δ        |
| CPA, (Y)           | Indirect               | 1      | 4      | Δ               | Δ        |
| CP A, rr           | Direct                 | 2      | 4      | $\Delta$        | Δ        |
| CPI A, #N          | Immediate              | 2      | 4      | Δ               | Δ        |
| DEC X              | Short Direct           | 1      | 4      | Δ               | *        |
| DEC Y              | Short Direct           | 1      | 4      | $\Delta$        | *        |
| DEC V              | Short Direct           | 1      | 4      | Δ               | *        |
| DEC W              | Short Direct           | 1      | 4      | $\Delta$        | *        |
| DEC A              | Direct                 | 2      | 4      | Δ               | *        |
| DEC rr             | Direct                 | 2      | 4      | Δ               | *        |
| DEC (X)            | Indirect               | 1      | 4      |                 | <b>^</b> |
| DEC (Y)            | Indirect               | 1      | 4      | Δ               | ^<br>    |
| INC X              | Short Direct           | 1      | 4      | Δ               | *        |
| INC Y              | Short Direct           | 1      | 4      | Δ               | *        |
|                    | Short Direct           | 1      | 4      | Δ               | *        |
|                    | Short Direct           | 1<br>2 | 4      | $\Delta$        | *        |
| INC A<br>INC rr    | Direct<br>Direct       | 2      | 4      | $\Delta \Delta$ | *        |
| INC II<br>INC (X)  | Indirect               | 1      | 4      | $\Delta$        | *        |
| INC (X)<br>INC (Y) | Indirect               | 1      | 4      |                 | *        |
| RLC A              | Inherent               | 1      | 4      | Δ               | Δ        |
|                    |                        |        |        |                 |          |
| SLA A              | Inherent               | 2      | 4      | Δ               | Δ        |
| SUB A, (X)         | Indirect               | 1      | 4      | Δ               | Δ        |
| SUB A, (Y)         | Indirect               | 1      | 4      | Δ               | Δ        |
| SUB A, rr          | Direct                 | 2      | 4      | Δ               | Δ        |
| SUBI A, #N         | Immediate              | 2      | 4      | Δ               | Δ        |

#### Table 18. Arithmetic & Logic Instructions

#### Notes:

#. Immediate data (stored in ROM memory)

rr. Data space register

Δ. Affected
 \* Not Affected

\* . Not Affected



X,Y.Indirect Register Pointers, V & W Short Direct Registers

Conditional Branch. The branch instructions achieve a branch in the program when the selected condition is met.

Bit Manipulation Instructions. These instructions can handle any bit in data space memory. One group either sets or clears. The other group (see Conditional Branch) performs the bit test branch operations.

Control Instructions. The control instructions control the MCU operations during program execution.

Jump and Call. These two instructions are used to perform long (12-bit) jumps or subroutines call inside the whole program space.

#### **Table 19. Conditional Branch Instructions**

| Instruction   | Branch If | Butoo | Civalaa | Flags |   |  |
|---------------|-----------|-------|---------|-------|---|--|
| instruction   | Branch II | Bytes | Cycles  | Z     | С |  |
| JRC e         | C = 1     | 1     | 2       | *     | * |  |
| JRNC e        | C = 0     | 1     | 2       | *     | * |  |
| JRZ e         | Z = 1     | 1     | 2       | *     | * |  |
| JRNZ e        | Z = 0     | 1     | 2       | *     | * |  |
| JRR b, rr, ee | Bit = 0   | 3     | 5       | *     | Δ |  |
| JRS b, rr, ee | Bit = 1   | 3     | 5       | *     | Δ |  |

Notes:

b. 3-bit address

5 bit signed displacement in the range -15 to +16 e.

ee. 8 bit signed displacement in the range -126 to +129

**Table 20. Bit Manipulation Instructions** 

rr. Data space register

 $\Delta$ . Affected Not Affected

\* . Not Affected

| Instruction | Addressing Mede | Button | Bytes Cycles Flags |   | ags |
|-------------|-----------------|--------|--------------------|---|-----|
| instruction | Addressing Mode | Byles  | Cycles             | Z | С   |
| SET b,rr    | Bit Direct      | 2      | 4                  | * | *   |
| RES b,rr    | Bit Direct      | 2      | 4                  | * | *   |

Notes:

b. 3-bit address;

rr. Data space register;

#### **Table 21. Control Instructions**

| Instruction | Addressing Mode | Bytes | Cycles | Flags    |   |  |
|-------------|-----------------|-------|--------|----------|---|--|
| Instruction | Addressing Mode |       | Cycles | Z        | С |  |
| NOP         | Inherent        | 1     | 2      | *        | * |  |
| RET         | Inherent        | 1     | 2      | *        | * |  |
| RETI        | Inherent        | 1     | 2      | $\Delta$ | Δ |  |
| STOP (1)    | Inherent        | 1     | 2      | *        | * |  |
| WAIT        | Inherent        | 1     | 2      | *        | * |  |

Notes:

1. This instruction is deactivated and a WAIT is automatically executed instead of a STOP if the Watchdog function is selected.

 $\Delta$  . Affected

Not Affected

#### Table 22. Jump & Call Instructions

| Instruction | Addressing Mede | <b>D</b> urfee | Civalaa | Flags |   |  |
|-------------|-----------------|----------------|---------|-------|---|--|
| Instruction | Addressing Mode | Bytes          | Cycles  | Z     | С |  |
| CALL abc    | Extended        | 2              | 4       | *     | * |  |
| JP abc      | Extended        | 2              | 4       | *     | * |  |

Notes: abc.12-bit address;



Opcode Map Summary. The following table contains an opcode map for the instructions used on the MCU.

| LOW       |                        |                 |                        |                      |                       |           |                       |        |                        |                      |                        |                       |                       |               |                       |                | LOW /     |
|-----------|------------------------|-----------------|------------------------|----------------------|-----------------------|-----------|-----------------------|--------|------------------------|----------------------|------------------------|-----------------------|-----------------------|---------------|-----------------------|----------------|-----------|
|           | 0000                   | 1<br>0001       | 2<br>0010              | 3<br>0011            | 4<br>0100             | 5<br>0101 | 6<br>0110             | 0111   | 8<br>1000              | 9<br>1001            | A<br>1010              | B<br>1011             | C<br>1100             | D<br>1101     | E<br>1110             | F<br>1111      |           |
| н         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 <b>JRZ</b>          |           | 2 JRC                 | 4 LD   | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 4 LDI         | 2 JRC                 | 4 LD           | И         |
| 0         | 2 JKNZ<br>e            | 4 CALL<br>abc   | 2 JKNC<br>e            | b0,rr,ee             | 2 JKZ                 | #         | 2 JKC                 | a,(x)  | 2 JRNZ                 | 4 JP<br>abc          | 2 JRNC<br>e            | 4 KES<br>b0.rr        | z JRZ                 | rr,nn         | 2 JRC                 | 4 LD<br>a,(y)  | 0         |
| 0000      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | #         | 1 pro                 |        | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 3 imm         | 1 pcr                 | a,(y)<br>1 ind | 0000      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 INC     | 2 JRC                 |        | 2 JRNZ                 | 4 JP                 | 2 JRNC                 |                       | 2 JRZ                 | 4 DEC         | 2 JRC                 | 4 LD           |           |
| 1         | e                      | abc             | e                      | b0,rr,ee             | e                     | x         | e                     | a,nn   | e                      | abc                  | e                      | b0,rr                 | e                     | ×             | e                     | a, rr          | 1         |
| 0001      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 | 1 '    | 1 pcr                  |                      | 1 pcr                  | , i                   | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          | 0001      |
|           | 2 JRNZ                 |                 | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | 2 JRC                 |        | · · · ·                | 4 JP                 | 2 JRNC                 |                       | 2 JRZ                 |               |                       | 4 CP           |           |
| 2         | е                      | abc             | е                      | b4,rr,ee             | е                     | #         | е                     | a,(x)  | e                      | abc                  | е                      | b4,rr                 | e                     | а             | е                     | a,(y)          | 2         |
| 0010      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1 pro                 | 1 ind  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh         | 1 pcr                 | 1 ind          | 0010      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 LD      | 2 JRC                 | 4 CPI  | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 LD          | 2 JRC                 | 4 CP           |           |
| 3<br>0011 | е                      | abc             | е                      | b4,rr,ee             | е                     | a,x       | е                     | a,nn   | е                      | abc                  | е                      | b4,rr                 | е                     | x,a           | е                     | a, rr          | 3<br>0011 |
| 0011      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 | 2 imm  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d.                | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          |           |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | 2 JRC                 | 4 ADD  | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 2 RETI        | 2 JRC                 | 4 ADD          |           |
| 4<br>0100 | е                      | abc             | е                      | b2,rr,ee             | е                     | #         | е                     | a,(x)  | e                      | abc                  | е                      | b2,rr                 | е                     |               | е                     | a,(y)          | 4<br>0100 |
| 0100      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1 pro                 | 1 ind  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh         | 1 pcr                 | 1 ind          | 0100      |
| _         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 INC     | 2 JRC                 | 4 ADDI | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 DEC         | 2 JRC                 | 4 ADD          | _         |
| 5<br>0101 | е                      | abc             | е                      | b2,rr,ee             | е                     | У         | е                     | a,nn   | е                      | abc                  | е                      | b2,rr                 | е                     | У             | е                     | a, rr          | 5<br>0101 |
| 0101      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 | 2 imm  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          | 0.01      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |           | 2 JRC                 | 4 INC  | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 2 STOP        | 2 JRC                 | 4 INC          |           |
| 6<br>0110 | е                      | abc             | е                      | b6,rr,ee             | е                     | #         | е                     | (x)    | e                      | abc                  | е                      | b6,rr                 | е                     |               | е                     | (y)            | 6<br>0110 |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1 pro                 |        |                        | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh         | 1 pcr                 | 1 ind          |           |
| 7         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 |           | 2 JRC                 |        | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 LD          | 2 JRC                 | 4 INC          | 7         |
| 0111      | е                      | abc             | е                      | b6,rr,ee             | е                     | a,y       | е                     | #      | e                      | abc                  | е                      | b6,rr                 | е                     | y,a           | е                     | rr             | 0111      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 |        | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          |           |
| 8         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |           | 2 JRC                 |        | 2 JRNZ                 | 4 <b>JP</b>          | 2 JRNC                 | 4 RES                 | 2 JRZ                 |               | 2 JRC                 | 4 LD           | 8         |
| 1000      | е                      | abc             | e                      | b1,rr,ee             | e                     | #         | e                     | (x),a  | e                      | abc                  | e                      | b1,rr                 | e                     | #             | е                     | (y),a          | 1000      |
|           | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 CALL | 1 pcr<br>2 <b>JRNC</b> | 3 bt<br>5 <b>JRS</b> | 1 pcr<br>2 <b>JRZ</b> | 4 INC     | 1 pro<br>2 <b>JRC</b> |        | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 <b>JP</b> | 1 pcr<br>2 <b>JRNC</b> | 2 b.d<br>4 <b>SET</b> | 1 pcr<br>2 <b>JRZ</b> | 4 DEC         | 1 pcr<br>2 <b>JRC</b> | 1 ind<br>4 LD  |           |
| 9         | -                      | -               |                        | b1,rr,ee             | -                     | 4 INC     |                       | #      | -                      | -                    |                        |                       | -                     | 4 DEC         |                       |                | 9         |
| 1001      | e<br>1 por             | abc<br>2 ext    | e<br>1 por             | 3 bt                 | e<br>1 por            | v<br>1 sd | e<br>1 pro            |        | e                      | abc<br>2 ext         | e<br>1 nor             | b1,rr<br>2 b.d        | e<br>1 nor            |               | e<br>1 pcr            | rr,a<br>2 dir  | 1001      |
|           | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 CALL | 1 pcr<br>2 <b>JRNC</b> | 5 <b>JRR</b>         | 1 pcr<br>2 <b>JRZ</b> | 1 30      | 1 pro<br>2 <b>JRC</b> |        | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 <b>JP</b> | 1 pcr<br>2 <b>JRNC</b> | 2 b.d<br>4 <b>RES</b> | 1 pcr<br>2 <b>JRZ</b> | 1 sd<br>4 RLC | 1 pcr<br>2 <b>JRC</b> | 2 uii<br>4 AND |           |
| Α         | e                      | abc             | e                      | b5,rr,ee             | e 0.02                | #         | e                     | a,(x)  | e                      | abc                  | e                      | b5,rr                 | 2 <b>3112</b>         | a             | e e                   | a,(y)          | A         |
| 1010      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | "         | 1 pro                 |        |                        | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh         | 1 pcr                 | 1 ind          | 1010      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 LD      | 2 JRC                 |        | 2 JRNZ                 | 4 JP                 | 2 JRNC                 |                       | 2 JRZ                 |               | 2 JRC                 | 4 AND          |           |
| в         | e                      | abc             | e                      | b5.rr.ee             | e                     | a.v       | e                     | a.nn   | e                      | abc                  | e                      | b5,rr                 | - • <u>-</u>          | v,a           | e                     | a,rr           | в         |
| 1011      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 | 2 imm  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          | 1011      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | 2 JRC                 |        | 2 JRNZ                 | 4 JP                 | 2 JRNC                 |                       | 2 JRZ                 |               |                       | 4 SUB          |           |
| C         | е                      | abc             | е                      | b3,rr,ee             | е                     | #         | е                     | a,(x)  | e                      | abc                  | e                      | b3,rr                 | e                     |               | e                     | a,(y)          | C         |
| 1100      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1 pro                 | 1 ind  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh         | 1 pcr                 | 1 ind          | 1100      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 INC     | 2 JRC                 | 4 SUBI | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 DEC         | 2 JRC                 | 4 SUB          |           |
| D<br>1101 | е                      | abc             | е                      | b3,rr,ee             | е                     | w         | е                     | a,nn   | е                      | abc                  | е                      | b3,rr                 | е                     | w             | е                     | a,rr           | D         |
| 1101      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 | 2 imm  | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          | 1101      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | 2 JRC                 | 4 DEC  | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 2 WAIT        | 2 JRC                 | 4 DEC          |           |
| E<br>1110 | е                      | abc             | е                      | b7,rr,ee             | е                     | #         | е                     | (x)    | e                      | abc                  | е                      | b7,rr                 | е                     |               | е                     | (y)            | E<br>1110 |
|           |                        | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1 pro                 |        |                        | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 |               | 1 pcr                 | 1 ind          |           |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 LD      | 2 JRC                 | ;      | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 LD          | 2 JRC                 | 4 DEC          |           |
| F<br>1111 | е                      | abc             | е                      | b7,rr,ee             | е                     | a,w       | е                     | #      | е                      | abc                  | е                      | b7,rr                 | е                     | w,a           | е                     | rr             | F 1111    |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1 pro                 | :      | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd          | 1 pcr                 | 2 dir          |           |

Abbreviations for Addressing Modes: dir Direct

- Short Direct sd Immediate
- imm Inherent inh
- Extended ext
- b.d Bit Direct
- bt Bit Test
- Program Counter Relative Indirect
- pcr ind

| Le | g | e | n | d | : |
|----|---|---|---|---|---|
|    |   |   |   |   |   |

# Indicates Illegal Instructions

5 Bit Displacement е

b 3 Bit Address

1byte dataspace address 1 byte immediate data rr

- nn
- abc 12 bit address
- ee 8 bit Displacement



## **ELECTRICAL CHARACTERISTICS**

#### Absolute Maximum Ratings

This product contains devices to protect the inputs against damage due to high static voltages, however it is advised to take normal precaution to avoid application of any voltage higher than maximum rated voltages.

For proper operation it is recommended that  $V_I$  and  $V_O$  must be higher than  $V_{SS}$  and smaller than  $V_{DD}$ . Reliability is enhanced if unused inputs are connected to an appropriated logic voltage level ( $V_{DD}$  or  $V_{SS}$ ). **Power Considerations.** The average chip-junction temperature, Tj, in Celsius can be obtained from:

 $Tj = T_A + PD x RthJA$ 

Where  $:T_A =$  Ambient Temperature.

RthJA = Package thermal resistance (junction-to ambient).

PD = Pint + Pport.

Pint =  $I_{DD} \times V_{DD}$  (chip internal power).

Pport = Port power dissipation (determinated by the user).

| Symbol           | Parameter                                                         | Value                                          | Unit |
|------------------|-------------------------------------------------------------------|------------------------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                                                    | -0.3 to 7.0                                    | V    |
| V <sub>LCD</sub> | Display Voltage                                                   | -0.3 to 11.0                                   | V    |
| VI               | Input Voltage                                                     | V <sub>SS</sub> - 0.3 to V <sub>DD</sub> + 0.3 | V    |
| Vo               | Output Voltage                                                    | V <sub>SS</sub> - 0.3 to V <sub>DD</sub> + 0.3 | V    |
| lo               | Current Drain per Pin Excluding V <sub>DD</sub> & V <sub>SS</sub> | ± 10                                           | mA   |
| IV <sub>DD</sub> | Total Current into V <sub>DD</sub> (source)                       | 50                                             | mA   |
| IV <sub>SS</sub> | Total Current out of V <sub>SS</sub> (sink)                       | 50                                             | mA   |
| Tj               | Junction Temperature                                              | 150                                            | °C   |
| T <sub>STG</sub> | Storage Temperature                                               | -60 to 150                                     | °C   |

**Note :** Stresses above those listed as "absolute maximum ratings" may cause permanent damage to the device . This is a stress rating only and functional operation of the device at these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

## THERMAL CHARACTERISTIC

| Symbol | Parameter          | Test Conditions |      | Unit |      |      |
|--------|--------------------|-----------------|------|------|------|------|
| Symbol |                    |                 | Min. | Тур. | Max. | Unit |
| RthJA  | Thermal Resistance | PQFP80          |      | 70   |      | °C/W |

### **RECOMMENDED OPERATING CONDITIONS**

| Symbol           | Parameter                | Test Condition s                     |          | Unit |          |      |
|------------------|--------------------------|--------------------------------------|----------|------|----------|------|
| Symbol           | i arameter               | rest conditions                      | Min.     | Тур. | Max.     | Onic |
| T <sub>A</sub>   | Operating Temperature    | 1 Suffix Version<br>6 Suffix Version | 0<br>-40 |      | 70<br>85 | °C   |
| V <sub>DD</sub>  | Operating Supply Voltage |                                      | 3        |      | 6        | V    |
| V <sub>LCD</sub> | Display Voltage          |                                      | 3        |      | 10       | V    |
| V <sub>DD</sub>  | RAM Retention Voltage    |                                      | 2        |      |          | V    |



### **RECOMMENDED OPERATING CONDITIONS** (Continued)

| Symbol            | Parameter                                                                                       | Test Condition s                                                    |              | Unit |            |      |
|-------------------|-------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--------------|------|------------|------|
| Symbol            | Falance                                                                                         | rest conditions                                                     | Min.         | Тур. | Max.       | Onic |
| fosc              | Oscillator Frequency <sup>(1)(4)</sup>                                                          | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01<br>0.01 |      | 8.388<br>2 | MHz  |
| I <sub>INJ+</sub> | Pin Injection Current (positive)<br>Digital Input <sup>(2)</sup><br>Analog Input <sup>(3)</sup> | V <sub>DD</sub> = 4.5 to 5.5V                                       |              |      | +5         | mA   |
| I <sub>INJ-</sub> | Pin Injection Current (negative)<br>Digital Input <sup>(2)</sup><br>Analog Input                | V <sub>DD</sub> = 4.5 to 5.5V                                       |              |      | -5         | mA   |

Notes :

1.

Otes : An oscillator frequency above 1MHz is recommanded for reliable A/D results. A current of ± 5mA can be forced on each pin of the digital section without affecting the functional behaviour of the device. For a positive current injected into one pin, a part of this current (~ 10%) can be expected to flow from the neighbouring pins. A current of -5mA can be forced on one input of the analog section at a time (or -2.5mA for all inputs at a time) without affecting the conversion. If a total current of +1mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 1mA, all the conversion is resulting shifted of +1LSB. If a total positive current of +5mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 5mA all the conversion, is resulting shifted of +2 B. 2.

3. current flowing into all the analog inputs is of 5mA, all the conversion is resulting shifted of +2LSB.
4. Operation below 0.01 MHz is possible but requires increased supply current.

### **EEPROM INFORMATION**

The ST62xx EEPROM single poly process has been specially developed to achieve 300.000 Write/Erase cycles and a 10 years data retention.

#### DC ELECTRICAL CHARACTERISTICS

(T<sub>A</sub> = -40 to +85°C unless otherwise specified)

| Symbol          | Parameter                 | Test Conditions                                                                                                                                                                                                                                             |                     | Value |                    | Unit           |
|-----------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------|--------------------|----------------|
| Gymbol          | rarameter                 |                                                                                                                                                                                                                                                             | Min.                | Тур.  | Max.               | onne           |
| VIL             | Input Low Level Voltage   | RESET, NMI, TIMER,<br>WDON Pin                                                                                                                                                                                                                              |                     |       | 0.3V <sub>DD</sub> | V              |
|                 |                           | TIMER                                                                                                                                                                                                                                                       | 0.80V <sub>DD</sub> |       |                    | V              |
| VIH             | Input High Level Voltage  | RESET, NMI,<br>WDON Pin                                                                                                                                                                                                                                     | 0.70V <sub>DD</sub> |       |                    | V              |
| Іц<br>Ін        | Input Leakage Current     | $\begin{array}{l} \text{RESET Pin} \\ \text{V}_{\text{DD}} = 5\text{V} \\ \text{V}_{\text{IN}} = \text{V}_{\text{DD}} \ ^{(1)} \\ \text{V}_{\text{IN}} = \text{V}_{\text{DD}} \ ^{(2)} \\ \text{V}_{\text{IN}} = \text{V}_{\text{SS}} \ ^{(5)} \end{array}$ |                     |       | 10<br>1<br>50      | μA<br>mA<br>μA |
| V <sub>OL</sub> | Low Level Output Voltage  | TIMER, $I_{OL} = 5.0 \text{mA}$                                                                                                                                                                                                                             |                     |       | 0.2V <sub>DD</sub> | v              |
| V <sub>OH</sub> | High Level Output Voltage | TIMER, I <sub>OL</sub> = -5.0mA                                                                                                                                                                                                                             | 0.65V <sub>DD</sub> |       |                    | V              |
| R <sub>PU</sub> | Pull-up Resistor          | V <sub>IN</sub> =0V V <sub>DD</sub> =5V<br>WDON - NMI                                                                                                                                                                                                       | 40                  | 100   | 200                | kΩ             |
|                 |                           | RESET                                                                                                                                                                                                                                                       | 200                 | 300   | 500                | kΩ             |

Notes on next page



## DC ELECTRICAL CHARACTERISTICS (Continued)

| Symbol                | Parameter                               | Test Conditions                                                  |      | Value |            | Unit |
|-----------------------|-----------------------------------------|------------------------------------------------------------------|------|-------|------------|------|
| Symbol                | Farameter                               | Test conditions                                                  | Min. | Тур.  | Max.       | Onic |
| I∟<br>I <sub>IH</sub> | Input Leakage Current                   | TIMER<br>V <sub>IN</sub> = V <sub>DD</sub> or V <sub>SS</sub>    |      | 0.1   | 1.0        | μA   |
| I∟<br>IH              | Input Leakage Current                   |                                                                  |      |       | 100<br>1.0 | μΑ   |
| I <sub>L</sub><br>Iн  | Input Leakage Current                   | $WDON VDD = 5V V_{IN} = V_{SS}^{(5)} V_{IN} = V_{DD}$            |      |       | 100<br>1.0 | μΑ   |
|                       | Supply Current RUN Mode                 | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$         |      | 4     | 7          | mA   |
| I <sub>DD</sub>       | Supply Current WAIT Mode <sup>(4)</sup> | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$         |      | 1     | 2          | mA   |
|                       | Supply Current RESET Mode               | f <sub>OSC</sub> = 8MHz,<br>V <sub>RESET</sub> = V <sub>SS</sub> |      | 1     | 7          | mA   |
|                       | Supply Current STOP Mode (3)(4)         | $I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$                              |      | 1     | 10         | μΑ   |

Notes : 1. No V 2. Res 3. Whe 4. All c 5. Pull-No Watchdog Reset activated. Reset generated by Watchdog. When the watchdog function is actvated the STOP instruction is deactivated. WAIT instruction is automatically executed. All on-chipperipherals in OFF state Pull-up resistor



## CURRENT CONSUMPTION





#### **AC ELECTRICAL CHARACTERISTICS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                           | Parameter Test Condition s                                          |         | Value          |            |        |  |
|------------------|-------------------------------------|---------------------------------------------------------------------|---------|----------------|------------|--------|--|
| Symbol           | Falameter                           | Test conditions                                                     | Min.    | Тур.           | Max.       | Unit   |  |
| fosc             | Oscillator Frequency <sup>(2)</sup> | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01    |                | 8.388<br>2 | MHz    |  |
| ts∪              | Oscillator Start-up Time            | $C_{L1} = C_{L2} = 22pF - crystal$                                  |         | 5              | 20         |        |  |
| t <sub>SR</sub>  | Supply Rise Time                    | 10% to 90%                                                          | 0.01    |                | 100        | ms     |  |
| t <sub>REC</sub> | Supply Recovery Time <sup>(1)</sup> |                                                                     | 100     |                |            |        |  |
| Tw               | Minimum Pulse Width                 | NMI Pin<br>V <sub>DD</sub> = 5V                                     | 100     |                |            | ns     |  |
|                  |                                     | RESET Pin                                                           | 100     |                |            | ns     |  |
| T <sub>WEE</sub> | EEPROM Write Time                   | $T_A = 25^{\circ}C$ One Byte<br>$T_A = 85^{\circ}C$ One Byte        |         | 5<br>15        | 10<br>25   | ms     |  |
| Endurance        | EEPROM WRITE/ERASE<br>Cycles        | Q <sub>A</sub> L <sub>OT</sub><br>Acceptance Criteria               | 300.000 | > 1<br>million |            | cycles |  |
| Retention        | EEPROM Data Retention               | $T_A = 55^{\circ}C$                                                 | 10      |                |            | years  |  |
| CIN              | Input Capacitance                   | All Inputs Pins                                                     |         |                | 10         | pF     |  |
| Cout             | Output Capacitance                  | All Outputs Pins                                                    |         |                | 10         | pF     |  |

Notes:

Period for which V<sub>DD</sub> has to be connected or at 0V to allow internal Reset function at next power-up.
 Operation below 0.01 MHz is possible but requires increased supply current.



### I/O PORTS

 $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwhise specified})$ 

| Symbol          | Parameter Test Condition s |                                                                  |                      | Unit |                      |      |
|-----------------|----------------------------|------------------------------------------------------------------|----------------------|------|----------------------|------|
| Symbol          | Farameter                  | Test Condition's                                                 | Min.                 | Тур. | Max.                 | Onit |
| VIL             | Input Low Level Voltage    | I/O Pins                                                         |                      |      | 0.3V <sub>DD</sub>   | V    |
| VIH             | Input High Level Voltage   | I/O Pins                                                         | $0.7V_{DD}$          |      |                      | V    |
|                 |                            | I/O Pins,<br>I <sub>O</sub> = 10μA (sink)                        |                      |      | 0.1                  | V    |
|                 | Low Level Output Voltage   | I/O Pins, $I_{OL} = V_{DD}x1mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |      | 0.16xV <sub>DD</sub> | V    |
|                 |                            | I/O Pins, $I_{OL} = 1.6mA$<br>$V_{DD} = 3V$                      |                      |      | 0.4                  | V    |
| V <sub>OL</sub> |                            | I/O Pins, $I_{OL} = V_{DD}x2mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |      | 0.16xV <sub>DD</sub> | V    |
|                 | Low Level Output Voltage,  | I/O Pins, $I_{OL} = 3.2mA$<br>$V_{DD} = 3V$                      |                      |      | 0.4                  | V    |
|                 | PB4-PB7 Only               | I/O Pins, $I_{OL} = V_{DD}x4mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |      | 0.26xV <sub>DD</sub> | V    |
|                 |                            | I/O Pins, $I_{OL} = 6.4mA$<br>$V_{DD} = 3V$                      |                      |      | 0.8                  | V    |
| Vон             | High Level Output Voltage  | I/O Pins,<br>I <sub>O</sub> = -10μA (source)                     | V <sub>DD</sub> -0.1 |      |                      | V    |
| VOH             |                            | I/O Pins, $I_{OL} = -V_{DD}x1mA$<br>$V_{DD} = 5.0V$              | 0.6xV <sub>DD</sub>  |      |                      | V    |
| I⊫<br>I⊞        | Input Leakage Current      | I/O Pins, <sup>(1)</sup>                                         |                      | 0.1  | 1.0                  | μΑ   |
| Rpu             | Pull-up Resistor           | I/O Pins $V_{IN} = 0V, V_{DD} = 5.0V$                            | 40                   | 100  | 200                  | KΩ   |

Note 1. Pull-up resistor off

## SPI ELECTRICAL CHARACTERISTICS

 $(V_{DD} = 5.0 \text{ V}, T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwhise specified})$ 

| Symbol         | vmbol Parameter Test |                    | Value |      |      | Unit |
|----------------|----------------------|--------------------|-------|------|------|------|
| Gymbol         | i didiliciti         | Test Conditions    | Min.  | Тур. | Max. | onic |
| Fc∟            | Clock Frequency      | applied on PB5/SCL |       |      | 1    | MHz  |
| ts∪            | Set-up Time          | applied on PB6/Sin |       | 50   |      | ns   |
| t <sub>h</sub> | Hold Time            | applied on PB6/Sin |       | 100  |      | ns   |



## A/D CONVERTER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                          | Parameter                                 | Test Conditions                                        | Value           |      |                 | Unit |
|---------------------------------|-------------------------------------------|--------------------------------------------------------|-----------------|------|-----------------|------|
| Gymbol                          |                                           |                                                        | Min.            | Тур. | Max.            | onit |
| Res                             | Resolution (3)                            |                                                        |                 | 8    |                 | Bit  |
| A <sub>TOT</sub>                | Total Accuracy (3)                        | f <sub>OSC</sub> > 1.2 MHz<br>f <sub>OSC</sub> > 32kHz |                 |      | ± 2<br>±4       | LSB  |
| tc <sup>(1)</sup>               | Conversion Time                           | f <sub>OSC</sub> = 8MHz                                |                 | 70   |                 | μs   |
| V <sub>AN</sub>                 | Conversion Range                          |                                                        | V <sub>SS</sub> |      | V <sub>DD</sub> | V    |
| ZIR                             | Zero Input Reading                        | Conversion result when $V_{IN} = V_{SS}$               | 00              |      |                 | Hex  |
| FSR                             | Full Scale Reading                        | Conversion result when $V_{IN} = V_{DD}$               |                 |      | FF              | Hex  |
| ADI                             | Analog Input Current During<br>Conversion | V <sub>DD</sub> = 4.5V                                 |                 |      | 1.0             | μΑ   |
| AC <sub>IN</sub> <sup>(2)</sup> | Analog Input Capacitance                  |                                                        |                 | 2    | 5               | pF   |
| ASI                             | Analog Source Impedance                   |                                                        |                 |      | 30              | kΩ   |
| SSI                             | Analog Reference Supply<br>Impedence      |                                                        |                 |      | 2               | kΩ   |

Notes:
1. With oscillator frequencies less than 1MHz, the A/D Converter accuracy is decreased.
2. Excluding Pad Capacitance
3. Noise at V<sub>DD</sub>,V<sub>SS</sub> ≤ 10mV



#### TIMER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol          | Parameter                    | Test Conditions                      |                      | Unit |                     |          |
|-----------------|------------------------------|--------------------------------------|----------------------|------|---------------------|----------|
| Gymbol          | i didiliciti                 |                                      | Min.                 | Тур. | Max.                |          |
| tres            | Resolution                   |                                      | $\frac{12}{f_{OSC}}$ |      |                     | second   |
| f <sub>IN</sub> | Input Frequency on TIMER Pin |                                      |                      |      | $\frac{f_{OSC}}{8}$ | MHz      |
| t <sub>W</sub>  | Pulse Width at TIMER Pin     | $V_{DD} \ge 3V$<br>$V_{DD} \ge 4.5V$ | 1<br>125             |      |                     | μs<br>ns |

#### **PSS ELECTRICAL CHARACTERISTICS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwhise specified})$ 

| Symbol Parameter |                       | Test Conditions                                                     | Value           |      |                 | Unit |
|------------------|-----------------------|---------------------------------------------------------------------|-----------------|------|-----------------|------|
| Gymbol           | i diameter            | Test conditions                                                     |                 | Тур. | Max.            | Onic |
| V <sub>PSS</sub> | PSS pin Input Voltage |                                                                     | V <sub>SS</sub> |      | V <sub>DD</sub> | V    |
| IPSS             | PSS pin Input Current | PSS RUN<br>PSS STOP<br>V <sub>PSS</sub> = 5V, T <sub>A</sub> = 25°C |                 |      | 350<br>1        | μΑ   |

### LCD ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                        | Test Conditions                              |      | Unit |      |      |
|------------------|----------------------------------|----------------------------------------------|------|------|------|------|
| Gymbol           | i ulumeter                       |                                              | Min. | Тур. | Max. | onic |
| f <sub>FR</sub>  | Frame Frequency                  | 1/4 Duty<br>f <sub>OSC</sub> = 1, 2, 4, 8MHz | 16   |      | 128  | Hz   |
| Vos              | DC Offset Voltage <sup>(1)</sup> | $V_{LCD} = V_{DD}$ , no load                 |      |      | 50   | mV   |
| V <sub>OH</sub>  | COM High Level, Output Voltage   | $I=100\mu A,V_{LCD}=5V$                      | 4.5V |      |      | V    |
| V <sub>OL</sub>  | COM Low Level, Output Voltage    | $I=100\mu A,\ V_{LCD}=5V$                    |      |      | 0.5V | V    |
| V <sub>OH</sub>  | SEG High Level, Output Voltage   | $I = 50 \mu A, V_{LCD} = 5 V$                | 4.5V |      |      | V    |
| Vol              | SEG Low Level, Output Voltage    | $I = 50 \mu A, V_{LCD} = 5 V$                |      |      | 0.5V | V    |
| V <sub>LCD</sub> | Display Voltage                  | Note 2                                       | 3    |      | 10   | V    |

#### Notes :

The DC offset voltage refers to all segment and common outputs. It is the difference between the measured voltage value and nominal value for every voltage level. Ri of voltage meter must be greater than or equal to 100MΩ.
 An external resistances network is required when V<sub>LCD</sub> ≤ 4.5V.



## PACKAGE MECHANICAL DATA

## Figure 56. ST6240 80 Pin Plastic Quad Flat Pack Package



| Dim. |       | mm    |        | inches |       |       |
|------|-------|-------|--------|--------|-------|-------|
|      | Min   | Тур   | Max    | Min    | Тур   | Max   |
| А    |       |       | 3.30   |        |       | 0.130 |
| A2   | 2.55  | 2.80  | 3.05   | 0.100  | 0.110 | 0.120 |
| D    |       | 23.20 |        |        | 0.913 |       |
| D1   | 19.90 | 20.00 | 20.10  | 0.783  | 0.787 | 0.791 |
| D3   |       | 18.40 |        |        | 0.724 |       |
| Е    |       | 17.20 |        |        | 0.677 |       |
| E1   | 13.90 | 14.00 | 14.10  | 0.547  | 0.551 | 0.555 |
| E3   |       | 12.00 |        |        | 0.472 |       |
| е    |       | 0.80  |        |        | 0.032 |       |
|      |       | 1     | Vumber | of Pin | s     |       |
| ND   |       |       | 2      | 4      |       |       |
| NE   | 16    |       |        |        |       |       |
| Ν    | 80    |       |        |        |       |       |

### **Short/Long Footprint Measurement**



## Short/Long Footprint recommended Padding





## PACKAGE MECHANICAL DATA (Continued)

## Recommended Solder Pad Footprint For QFP80 (in mm)





#### ORDERING INFORMATION

The following chapter deals with the procedure for transfer the Program/Data ROM codes to SGS-THOMSON.

Communication of the ROM Codes. To communicate the contents of Program/Data ROM memories to SGS-THOMSON, the customer has to send :

- one file in INTEL INTELLEC 8/MDS FORMAT (in an MS-DOS 5" diskette) for the PROGRAM Memory
- one file in INTEL INTELLEC 8/MDS FORMAT (in a MS-DOS 5" diskette) for the EEPROM initial content (this file is optional)
- a filled Option List form as described in the OPTION LIST paragraph.

The program ROM should respect the ROM Memory Map as in Table 23.

The ROM code must be generated with ST6 assembler. Before programming the EPROM, the buffer of the EPROM programmer must be filled with FFh.

| ROM Page           | Device Address                                                                         | Description                                                                         |
|--------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| Page 0             | 0000h-007Fh<br>0080h-07FFh                                                             | Reserved<br>User ROM                                                                |
| Page 1<br>"STATIC" | 0800h-0F9Fh<br>0FA0h-0FEFh<br>0FF0h-0FF7h<br>0FF8h-0FFBh<br>0FFCh-0FFDh<br>0FFEh-0FFFh | User ROM<br>Reserved<br>Interrupt Vectors<br>Reserved<br>NMI Vector<br>Reset Vector |
| Page 2             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                |
| Page 3             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                |

Table 23. ROM Memory Map

Note : EPROM addresses are related to the ROM file to be processed.

#### **Customer EEPROM Initial Contents :** Format

a. The content should be written into an INTEL INTELLEC format file.

b. In the case of 128 bytes of EEPROM, the starting address in 000h and the end in 7Fh.

c. Undefined or don't care bytes should have the content FFh.

Listing Generation & Verification. When SGS-THOMSON receives the Codes, they are compared and a computer listing is generated from them. This listing refers exactly to the mask that will be used to produce the microcontroller. Then the listing is returned to the customer that must thoroughly check, complete, sign and return it to SGS-THOMSON. The signed list constitutes a part of the contractual agreement for the creation of the customer mask. SGS-THOMSON sales organization will provide detailed information on contractual points.

### ORDERING INFORMATION TABLE

| Sales Types | Temperature Range | Package |
|-------------|-------------------|---------|
| ST6240Q1/XX | 0 to + 70°C       | PQFP80  |
| ST6240Q6/XX | -40 to + 85°C     | PQFP80  |

Note : "XX" is the ROM code identifier allocated by SGS-THOMSON after receipt of all required options and the related ROM file.



| ST6240 MICROCONTROLLER OPTION LIST                                                                                                        |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Customer                                                                                                                                  |  |  |  |  |  |
| Address                                                                                                                                   |  |  |  |  |  |
|                                                                                                                                           |  |  |  |  |  |
| Phone No                                                                                                                                  |  |  |  |  |  |
| Reference                                                                                                                                 |  |  |  |  |  |
|                                                                                                                                           |  |  |  |  |  |
| SGS-THOMSON Microelectronics references                                                                                                   |  |  |  |  |  |
| Device []ST6240                                                                                                                           |  |  |  |  |  |
| Package[] Plastic Quad Flat PackageTemperature Range[] 0°C to + 70°C[] -40°C to + 85°C                                                    |  |  |  |  |  |
| Special Marking [ ] No<br>[ ] Yes ""                                                                                                      |  |  |  |  |  |
| Authorized characters are Letters, digits, '.', '-', '/' and spaces only.<br>For marking one line with 10 characters maximum is possible. |  |  |  |  |  |
| Comments :<br>- Number of LCD segments used :<br>- Number of LCD backplanes used :<br>- PSS used:                                         |  |  |  |  |  |
| Note :                                                                                                                                    |  |  |  |  |  |
|                                                                                                                                           |  |  |  |  |  |
| Signature                                                                                                                                 |  |  |  |  |  |
| Date                                                                                                                                      |  |  |  |  |  |



ST6240

Notes:





# ST62E40 ST62T40

## 8-BIT OTP/EPROM HCMOS MCUs WITH LCD DRIVER,EEPROM AND A/D CONVERTER

- 3 to 6V supply operating range
- 8.4MHz Maximum Clock Frequency
- Run, Wait & Stop Modes
- 5 different interrupt vectors
- Look-up table capability in EPROM

| User EPROM: | 7948 bytes |
|-------------|------------|
| Data RAM:   | 192 bytes  |
| LCD RAM:    | 24 bytes   |
| EEPROM:     | 128 bytes  |

- PQFP80 and CQFP80-W packages
- 16 fully software programmable I/O as:
  - Input with/without pull-up resistor
  - Input with interrupt generation
  - Open-Drain or Push-pull outputs
  - Analog Inputs (12 pins)
- 4 I/O lines can sink up to 20mA for direct LED or TRIAC driving and have SPI alternate functions
- Two 8-bit counters and 7-bit programmable prescalers (Timer 1 and 2)
- Software or hardware activated digital watchdog
- 8-bit A/D converter with up to 12 analog inputs
- 8-bit synchronous serial peripheral interface (SPI)
- LCD driver with 45 segment outputs, 4 backplane outputs and selectable duty cycle for up to 180 LCD segments direct driving
- 32kHz oscillator for stand-by LCD operation
- Power Supply Supervisor (PSS)
- One external not maskable interrupt
- 9 powerful addressing modes
- The accumulator, the X, Y, V & W registers, the port and peripherals data & control registers are addressed in the data space as RAM locations.
- The ST62E40 is the EPROM version, ST62T40 is the OTP version, fully compatible with ST6240 ROM version.



April 1995

This is Preliminary data from SGS-THOMSON, details are subject to change without notice.

## ST62E40 - ST62T40



## Figure 1. 80 Pin Quad Flat Pack (QFP) Package Pinout

## ST62E40/T40 Pin Description

| Pin<br>number | Pin<br>name          | Pin<br>number | Pin<br>name             | Pin<br>number | Pin<br>name | Pin<br>number | Pin<br>name |
|---------------|----------------------|---------------|-------------------------|---------------|-------------|---------------|-------------|
| 1             | S43                  | 25            | RESET                   | 64            | S26         | 65            | S27         |
| 2             | S44                  | 26            | OSCout                  | 63            | S25         | 66            | S28         |
| 3             | S45                  | 27            | OSCin                   | 62            | S24         | 67            | S29         |
| 4             | S46                  | 28            | WDON                    | 61            | S23         | 68            | S30         |
| 5             | S47                  | 29            | NMI                     | 60            | S22         | 69            | S31         |
| 6             | S48                  | 30            | TIMER                   | 59            | S21         | 70            | S32         |
| 7             | COM4                 | 31            | PB7/Sout <sup>(1)</sup> | 58            | S20         | 71            | S33         |
| 8             | COM3                 | 32            | PB6/Sin <sup>(1)</sup>  | 57            | S19         | 72            | S34         |
| 9             | COM2                 | 33            | PB5/SCL <sup>(1)</sup>  | 56            | S18         | 73            | S35         |
| 10            | COM1                 | 34            | PB4 <sup>(1)</sup>      | 55            | S17         | 74            | S36         |
| 11            | VLCD1/3              | 35            | PB3/Ain                 | 54            | S16         | 75            | S37         |
| 12            | VLCD2/3              | 36            | PB2/Ain                 | 53            | S15         | 76            | S38         |
| 13            | VLCD                 | 37            | PB1/Ain                 | 52            | S14         | 77            | S39         |
| 14            | PA7/Ain              | 38            | PB0/Ain                 | 51            | S13         | 78            | S40         |
| 15            | PA6/Ain              | 39            | OSC32out                | 50            | S12         | 79            | S41         |
| 16            | PA5/Ain              | 40            | OSC32in                 | 49            | S11         | 80            | S42         |
| 17            | PA4/Ain              |               |                         | 48            | S10         |               |             |
| 18            | TEST/V <sub>PP</sub> |               |                         | 47            | S9          |               |             |
| 19            | PA3/Ain              |               |                         | 46            | S8          |               |             |
| 20            | PA2/Ain              |               |                         | 45            | S7          |               |             |
| 21            | PA1/Ain              |               |                         | 44            | S6          |               |             |
| 22            | PA0/Ain              |               |                         | 43            | S5          |               |             |
| 23            | V <sub>DD</sub>      |               |                         | 42            | S4          |               |             |
| 24            | V <sub>SS</sub>      |               |                         | 41            | PSS         |               |             |

Note 1: 20mA Sink



#### **GENERAL DESCRIPTION**

The ST62E40,T40 microcontrollers are members of the 8-bit HCMOS ST62xx family, a series of devices oriented to low-medium complexity applications. They are the EPROM/OTP versions of the ST6240 ROM device and are suitable for product prototyping and low volume production. All ST62xx members are based on a building block approach: a common core is associated with a combination of on-chip peripherals (macrocells). The macrocells of the ST6240 family are: a high performance LCD controller/driver with 45 segment outputs and 4 backplanes able to drive up to 180 segments, two Timer peripherals each including an 8-bit counter with a 7-bit software programmable prescaler (Timer), the digital watchdog timer (DWD), an 8-bit A/D Converter with up to 12 analog inputs, a Power Supply Supervisor and an 8-bit synchronous Serial Peripheral Interface (SPI). In addition these devices offer 128 bytes of EEPROM for storage of non volatile data. Thanks to these peripherals the ST6240 family is well suited for general purpose, automotive, security, appliance and industrial applications.



Figure 2. ST62E40 Block Diagram

Note: Ain = Analog Input



#### PIN DESCRIPTION

 $V_{DD}$  and  $V_{SS}.$  Power is supplied to the MCU using these two pins.  $V_{DD}$  is power and  $V_{SS}$  is the ground connection.

**OSCin and OSCout**. These pins are internally connected with the on-chip oscillator circuit. A quartz crystal or a ceramic resonator can be connected between these two pins in order to allow the correct operation of the MCU with various stability/cost trade-offs. OSCin is the input pin, OSCout is the output pin. An external clock signal can be applied to OSCin.

**RESET.** The active low **RESET** pin is used to restart the microcontroller at the beginning of its program. The **RESET** pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TEST/VPP.** The TEST must be held at V<sub>SS</sub> for normal operation (an internal pull-down resistor selects normal operating mode if TEST pin is not connected).

**NMI.** The NMI pin provides the capability for asynchronous applying an external top priority interrupt to the MCU. This pin is falling edge sensitive. The NMI pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TIMER.** This is the TIMER 1 I/O pin. In input mode it is connected to the prescaler and acts as external timer clock or as control gate for the internal timer clock. In the output mode the TIMER pin outputs the data bit when a time-out occurs.

**WDON.** This pin selects the watchdog enabling option (hardware or software). A low level selects the hardware activated option (the watchdog is always active), a high level selects the software activated option (the watchdog can be activated by software, deactivated only by reset, thus enabling STOP mode). An internal pull-up resistance selects the software watchdog option if the WDON pin is not connected.

**PA0-PA7.** These 8 lines are organized as one I/O port (A). Each line may be configured under software control as an input with or without pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output or as analog input for the A/D converter. Port A has a 5mA drive capability in output mode.

**PB0-PB3,PB4-PB7.** These 8 lines are organized as one I/O port (B). Each line may be configured under software control as an input with or without internal pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output. PB0-PB3 can be programmed as analog inputs for the A/D converter while PB4-PB7 can also sink 20mA for direct LED driving. PB5-PB7 can also be used as respectively Clock, Data in and Data out pins for the on-chip SPI to carry the synchronous serial I/O signals.

**COM1-COM4.** These four pins are the LCD peripheral common outputs. They are the outputs of the on-chip backplane voltage generator which is used for multiplexing the 45 LCD lines allowing up to 180 segments to be driven.

**S4-S48.** These pins are the 45 LCD peripheral driver outputs of ST6240. Segments S1-S3 are not connected to any pin.

**VLCD.** Display voltage supply. It determines the high voltage level on COM1-COM4 and S4-S48 pins.

VLCD1/3, VLCD2/3. Display supply voltage inputs for determining the display voltage levels on COM1-COM4 and S4-S48 pins during multiplex operation.

**PSS.** This is the Power Supply Supervisor sensing pin. When the voltage applied to this pin is falling below a software programmed value the highest priority (NMI) interrupt can be generated. This pin has to be connected to the voltage to be supervised.

**OSC32in and OSC32out.** These pins are internally connected with the on-chip 32kHz oscillator circuit. A 32.768kHz quartz crystal can be connected between these two pins if it is necessary to provide the LCD stand-by clock and real time interrupt. OSC32in is the input pin, OSC32out is the output pin.



#### ST62E40,T40 EPROM/OTP DESCRIPTION

The ST62E40 is the EPROM version of the ST6240 ROM product. It is intended for use during the development of an application, and for pre-production and small volume production. The ST62T40 OTP has the same characteristics. Both include EPROM memory instead of the ROM memory of the ST6240, and so the program and constants of the program can be easily modified by the user with the ST62E40 EPROM programming board from SGS-THOMSON.

From a user point of view (with the following exception) the ST62E40, T40 products have exactly the same software and hardware features of the ROM version. An additional mode is used to configure the part for programming of the EPROM, this is set by a +12.5V voltage applied to the TEST/V<sub>PP</sub> pin. The programming of the ST62E40, T40 is described in the User Manual of the EPROM Programming board.

On the ST62E40, all the 8192 bytes of PROGRAM memory are available for the user, as all the EPROM memory can be erased by exposure to UV light. On the ST62T40 (OTP) device) a reserved area for test purposes exists, as for the ST6240 ROM device. In order to avoid any discrepancy between program functionality when using the EPROM, OTP and ROM it is recommended not to use these reserved areas, even when using the ST62E40.

Other than this exception, the ST62E40,T40 parts are fully compatible with the ROM ST6240 equivalent, this datasheet thus provides only information specific to the EPROM based devices.

#### THE READER IS ASKED TO REFER TO THE DATASHEET OF THE ST6240 ROM-BASED DE-VICE FOR FURTHER DETAILS.

#### **EPROM ERASING**

The EPROM of the windowed package of the ST62E40 may be erased by exposure to Ultra Violet light.

The erasure characteristic of the ST62E40 EPROM is such that erasure begins when the memory is exposed to light with wave lengths shorter than approximately 4000Å. It should be noted that sunlight and some types of fluorescent lamps have wavelengths in the range 3000-4000Å. It is thus recommended that the window of the ST62E40 package be covered by an opaque label to prevent unintentional erasure problems when testing the application in such an environment.

The recommended erasure procedure of the ST62E40 EPROM is exposure to short wave ultraviolet light which has wavelength 2537Å. The integrated dose (i.e. UV intensity x exposure time) for erasure should be a minimum of 15 W-sec/cm<sup>2</sup>. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with 12000 $\mu$ W/cm<sup>2</sup> power rating. The ST62E40 should be placed within 2.5 cm (1 inch) of the lamp tubes during erasure.



#### **ELECTRICAL CHARACTERISTICS**

#### Absolute Maximum Ratings

This product contains devices to protect the inputs against damage due to high static voltages, however it is advised to take normal precaution to avoid application of any voltage higher than maximum rated voltages.

For proper operation it is recommended that  $V_I$  and  $V_O$  must be higher than  $V_{SS}$  and smaller than  $V_{DD}$ . Reliability is enhanced if unused inputs are connected to an appropriated logic voltage level ( $V_{DD}$  or  $V_{SS}$ ). **Power Considerations.**The average chip-junction temperature, Tj, in Celsius can be obtained from:

| Tj =              | T <sub>A</sub> + PD x RthJA                                  |
|-------------------|--------------------------------------------------------------|
| Where : . $T_A =$ | Ambient Temperature.                                         |
|                   | Package thermal resistance (junction-to ambient).            |
| PD = .            | Pint + Pport.                                                |
| Pint = .          | $I_{\text{DD}} \; x \; V_{\text{DD}}$ (chip internal power). |
|                   | Port power dissipation (determinated by the user).           |

| Symbol           | Parameter                                           | Value                                          | Unit |
|------------------|-----------------------------------------------------|------------------------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                                      | -0.3 to 7.0                                    | V    |
| V <sub>LCD</sub> | Display Voltage                                     | -0.3 to 11.0                                   | V    |
| VI               | Input Voltage                                       | $V_{SS}$ - 0.3 to $V_{DD}$ + 0.3               | V    |
| Vo               | Output Voltage                                      | V <sub>SS</sub> - 0.3 to V <sub>DD</sub> + 0.3 | V    |
| lo               | Current Drain per Pin Excluding $V_{DD}$ & $V_{SS}$ | ± 10                                           | mA   |
| IV <sub>DD</sub> | Total Current into V <sub>DD</sub> (source)         | 50                                             | mA   |
| IV <sub>SS</sub> | Total Current out of V <sub>SS</sub> (sink)         | 50                                             | mA   |
| Tj               | Junction Temperature                                | 150                                            | °C   |
| T <sub>STG</sub> | Storage Temperature                                 | -60 to 150                                     | °C   |

Note: Stresses above those listed as "absolute maximum ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

#### THERMAL CHARACTERISTIC

| Symbol | Parameter          | Test Conditions    |      | Value |      | Unit |
|--------|--------------------|--------------------|------|-------|------|------|
| Symbol | Falameter          | Test conditions    | Min. | Тур.  | Max. | Onic |
| RthJA  | Thermal Resistance | PQFP80<br>CQFP80-W |      | 70    |      | °C/W |

#### **RECOMMENDED OPERATING CONDITIONS**

| Symbol           | Parameter                | Test Condition s                     |          | Unit |          |      |
|------------------|--------------------------|--------------------------------------|----------|------|----------|------|
| Symbol           | rarameter                | rest conditions                      | Min.     | Тур. | Max.     | onit |
| T <sub>A</sub>   | Operating Temperature    | 1 Suffix Version<br>6 Suffix Version | 0<br>-40 |      | 70<br>85 | °C   |
| V <sub>DD</sub>  | Operating Supply Voltage |                                      | 3        |      | 6        | V    |
| V <sub>LCD</sub> | Display Voltage          |                                      | 3        |      | 10       | V    |



#### RECOMMENDED OPERATING CONDITIONS (Continued)

| Symbol            | Parameter                                                                                       | Test Condition s                     |              | Unit |            |      |
|-------------------|-------------------------------------------------------------------------------------------------|--------------------------------------|--------------|------|------------|------|
| Symbol            | Falance                                                                                         | rest conditions                      | Min.         | Тур. | Max.       | Unit |
| V <sub>RM</sub>   | RAM Retention Voltage                                                                           |                                      | 2            |      |            | V    |
| fosc              | Oscillator Frequency <sup>(1)(4)</sup>                                                          | $V_{DD} \ge 4.5V$<br>$V_{DD} \ge 3V$ | 0.01<br>0.01 |      | 8.388<br>2 | MHz  |
| I <sub>INJ+</sub> | Pin Injection Current (positive)<br>Digital Input <sup>(2)</sup><br>Analog Input <sup>(3)</sup> | V <sub>DD</sub> = 4.5 to 5.5V        |              |      | +5         | mA   |
| l <sub>inj-</sub> | Pin Injection Current (negative)<br>Digital Input <sup>(2)</sup><br>Analog Input                | V <sub>DD</sub> = 4.5 to 5.5V        |              |      | -5         | mA   |

Notes :

1. An oscillator frequency above 1MHz is recommanded for reliable A/D results.

2. A current of ± 5mA can be forced on each pin of the digital section without affecting the functional behaviour of the device. For a positive current injected into one pin, a part of this current (~ 10%) can be expected to flow from the neighbouring pins. A current of -5mA can be forced on one input of the analog section at a time (or -2.5mA for all inputs at a time) without affecting the conversion.

- 3. If a total current of +1mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 1mA, all the conversion is resulting shifted of +1LSB. If a total positive current of +5mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 5mA, all the conversion is resulting shifted of +2LSB.
- 4. Operation below 0.01 MHz is possible but requires increased supply current.

#### **EEPROM INFORMATION**

The ST62xx EEPROM single poly process has been specially developed to achieve 300.000 Write/Erase cycles and a 10 years data retention.

#### DC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                 | Parameter                 | Test Conditions                 |                     | Value |                    | Unit           |
|------------------------|---------------------------|---------------------------------|---------------------|-------|--------------------|----------------|
| Symbol                 |                           |                                 | Min.                | Тур.  | Max.               | Onic           |
| VIL                    | Input Low Level Voltage   | RESET, NMI, TIMER,<br>WDON Pin  |                     |       | 0.3V <sub>DD</sub> | V              |
|                        |                           | TIMER                           | 0.80V <sub>DD</sub> |       |                    | V              |
| Vih                    | Input High Level Voltage  | RESET, NMI,<br>WDON Pin         | 0.70V <sub>DD</sub> |       |                    | V              |
| I <sub>IL</sub><br>IIH | Input Leakage Current     |                                 |                     |       | 10<br>1<br>50      | μA<br>mA<br>μA |
| V <sub>OL</sub>        | Low Level Output Voltage  | TIMER, I <sub>OL</sub> = 5.0mA  |                     |       | 0.2V <sub>DD</sub> | V              |
| V <sub>OH</sub>        | High Level Output Voltage | TIMER, I <sub>OL</sub> = -5.0mA | 0.65V <sub>DD</sub> |       |                    | V              |

Notes on next page



## ST62E40 - ST62T40

## DC ELECTRICAL CHARACTERISTICS (Continued)

| Symbol                 | Parameter Test Cond                        | Test Conditions                                                  |      | Value |            | Unit |
|------------------------|--------------------------------------------|------------------------------------------------------------------|------|-------|------------|------|
| Symbol                 | Farameter                                  |                                                                  | Min. | Тур.  | Max.       | Onit |
| R <sub>PU</sub>        | Pull-up Resistor                           | V <sub>IN</sub> =0V V <sub>DD</sub> =5V<br>WDON - NMI            | 40   | 100   | 200        | kΩ   |
|                        |                                            | RESET                                                            | 200  | 300   | 500        | kΩ   |
| l <sub>IL</sub><br>lih | Input Leakage Current                      | TIMER<br>VIN = V <sub>DD</sub> or V <sub>SS</sub>                |      | 0.1   | 1.0        | μΑ   |
| I <sub>IL</sub><br>Iін | Input Leakage Current                      |                                                                  |      |       | 100<br>1.0 | μΑ   |
| І∟<br>Ін               | Input Leakage Current                      | $WDON VDD = 5V V_{IN} = V_{SS} (5) V_{IN} = V_{DD}$              |      |       | 100<br>1.0 | μΑ   |
|                        | Supply Current RUN Mode                    | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.5V$         |      | 4     | 7          | mA   |
| I <sub>DD</sub>        | Supply Current WAIT Mode (4)               | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$         |      | 1     | 2          | mA   |
|                        | Supply Current RESET Mode                  | f <sub>OSC</sub> = 8MHz,<br>V <sub>RESET</sub> = V <sub>SS</sub> |      | 1     | 7          | mA   |
|                        | Supply Current STOP Mode <sup>(3)(4)</sup> | I <sub>LOAD</sub> = 0mA<br>V <sub>DD</sub> = 5.5V                |      | 1     | 10         | μΑ   |

Notes :

1. No Watchdog Reset activated.

2. Reset generated by Watchdog.

3. When the watchdog function is actvated the STOP instruction is deactivated. WAIT instruction is automatically executed.

4. All on-chip peripherals in OFF state

5. Pull-up resistor



## AC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                           | Test Condition s                                                    |         | Value          |            | Unit   |
|------------------|-------------------------------------|---------------------------------------------------------------------|---------|----------------|------------|--------|
| Symbol           | Farameter                           | rest conditions                                                     | Min.    | Тур.           | Max.       | Onic   |
| fosc             | Oscillator Frequency <sup>(2)</sup> | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01    |                | 8.388<br>2 | MHz    |
| t <sub>SU</sub>  | Oscillator Start-up Time            | $C_{L1} = C_{L2} = 22pF - crystal$                                  |         | 5              | 20         |        |
| t <sub>SR</sub>  | Supply Rise Time                    | 10% to 90%                                                          | 0.01    |                | 100        | ms     |
| t <sub>REC</sub> | Supply Recovery Time <sup>(1)</sup> |                                                                     | 100     |                |            |        |
| Tw               | Minimum Pulse Width                 | NMI Pin<br>V <sub>DD</sub> = 5V                                     | 100     |                |            | ns     |
|                  |                                     | RESET Pin                                                           | 100     |                |            | ns     |
| T <sub>WEE</sub> | EEPROM Write Time                   | $T_A = 25^{\circ}C$ One Byte<br>$T_A = 85^{\circ}C$ One Byte        |         | 5<br>15        | 10<br>25   | ms     |
| Endurance        | EEPROM WRITE/ERASE<br>Cycles        | Q <sub>A</sub> L <sub>OT</sub><br>Acceptance Criteria               | 300.000 | > 1<br>million |            | cycles |
| Retention        | EEPROM Data Retention               | $T_A = 55^{\circ}C$                                                 | 10      |                |            | years  |
| C <sub>IN</sub>  | Input Capacitance                   | All Inputs Pins                                                     |         |                | 10         | pF     |
| Соит             | Output Capacitance                  | All Outputs Pins                                                    |         |                | 10         | pF     |

Notes:

1. Period for which  $V_{DD}$  has to be connected or at 0V to allow internal Reset function at next power-up.

2. Operation below 0.01 MHz is possible but requires increased supply current.



#### **I/O PORTS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                             | Parameter                 | Test Condition s                                           |                      | Value |                      | Unit |
|------------------------------------|---------------------------|------------------------------------------------------------|----------------------|-------|----------------------|------|
| Symbol                             | Parameter                 | Test Condition's                                           | Min.                 | Тур.  | Max.                 | Unit |
| VIL                                | Input Low Level Voltage   | I/O Pins                                                   |                      |       | 0.3V <sub>DD</sub>   | V    |
| VIH                                | Input High Level Voltage  | I/O Pins                                                   | $0.7V_{DD}$          |       |                      | V    |
|                                    |                           | I/O Pins,<br>I <sub>O</sub> = 10μA (sink)                  |                      |       | 0.1                  | V    |
|                                    | Low Level Output Voltage  | I/O Pins, $I_{OL} = V_{DD}x1mA$<br>$V_{DD} = 4.5$ to 6V    |                      |       | 0.16xV <sub>DD</sub> | V    |
|                                    |                           | I/O Pins, $I_{OL} = 1.6mA$<br>$V_{DD} = 3V$                |                      |       | 0.4                  | V    |
| Vol                                |                           | I/O Pins, $I_{OL} = V_{DD}x2mA$<br>$V_{DD} = 4.5$ to 6V    |                      |       | 0.16xV <sub>DD</sub> | V    |
|                                    | Low Level Output Voltage, | I/O Pins, $I_{OL} = 3.2mA$<br>V <sub>DD</sub> = 3V         |                      |       | 0.4                  | V    |
|                                    | PB4-PB7 Only              | I/O Pins, $I_{OL} = V_{DD}x4mA$<br>$V_{DD} = 4.5$ to 6V    |                      |       | 0.26xV <sub>DD</sub> | V    |
|                                    |                           | I/O Pins, $I_{OL} = 6.4 \text{mA}$<br>V <sub>DD</sub> = 3V |                      |       | 0.8                  | V    |
| V <sub>он</sub>                    | High Level Output Voltage | I/O Pins,<br>I <sub>O</sub> = -10μA (source)               | V <sub>DD</sub> -0.1 |       |                      | V    |
| ¥0H                                |                           | I/O Pins, $I_{OL} = -V_{DD}x1mA$<br>$V_{DD} = 5.0V$        | 0.6xV <sub>DD</sub>  |       |                      | V    |
| I <sub>IL</sub><br>I <sub>IH</sub> | Input Leakage Current     | I/O Pins, <sup>(1)</sup>                                   |                      | 0.1   | 1.0                  | μΑ   |
| R <sub>PU</sub>                    | Pull-up Resistor          | I/O Pins $V_{IN} = 0V, V_{DD} = 5.0V$                      | 40                   | 100   | 200                  | kΩ   |

Note 1. Pull-up resistor off

### SPI ELECTRICAL CHARACTERISTICS

 $(V_{DD} = 5.0 \text{ V}, T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwhise specified})$ 

| Symbol         | Parameter       | Test Conditions    |      | Value |      | Unit |
|----------------|-----------------|--------------------|------|-------|------|------|
| Gymbol         | i didiliciti    |                    | Min. | Тур.  | Max. | onit |
| Fc∟            | Clock Frequency | applied on PB5/SCL |      |       | 1    | MHz  |
| ts∪            | Set-up Time     | applied on PB6/Sin |      | 50    |      | ns   |
| t <sub>h</sub> | Hold Time       | applied on PB6/Sin |      | 100   |      | ns   |



#### A/D CONVERTER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                          | Parameter                                 | Test Conditions                                        |                 | Value |                 | Unit |
|---------------------------------|-------------------------------------------|--------------------------------------------------------|-----------------|-------|-----------------|------|
| Gymbol                          | i di diffetteri                           |                                                        | Min.            | Тур.  | Max.            | onit |
| Res                             | Resolution (3)                            |                                                        |                 | 8     |                 | Bit  |
| A <sub>TOT</sub>                | Total Accuracy (3)                        | f <sub>OSC</sub> > 1.2 MHz<br>f <sub>OSC</sub> > 32kHz |                 |       | ± 2<br>±4       | LSB  |
| tc <sup>(1)</sup>               | Conversion Time                           | f <sub>OSC</sub> = 8MHz                                |                 | 70    |                 | μs   |
| V <sub>AN</sub>                 | Conversion Range                          |                                                        | V <sub>SS</sub> |       | V <sub>DD</sub> | V    |
| ZIR                             | Zero Input Reading                        | Conversion result when $V_{IN} = V_{SS}$               | 00              |       |                 | Hex  |
| FSR                             | Full Scale Reading                        | Conversion result when $V_{IN} = V_{DD}$               |                 |       | FF              | Hex  |
| ADI                             | Analog Input Current During<br>Conversion | V <sub>DD</sub> = 4.5V                                 |                 |       | 1.0             | μA   |
| AC <sub>IN</sub> <sup>(2)</sup> | Analog Input Capacitance                  |                                                        |                 | 2     | 5               | pF   |
| ASI                             | Analog Source Impedance                   |                                                        |                 |       | 30              | kΩ   |
| SSI                             | Analog Reference Supply<br>Impedence      |                                                        |                 |       | 2               | kΩ   |

Notes:

1. With oscillator frequencies less than 1MHz, the A/D Converter accuracy is decreased.

2. Excluding Pad Capacitance

3. Noise at  $V_{DD}$ ,  $V_{SS} \le 10 mV$ 



#### TIMER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                    | Test Conditions                      |                      | Unit |                     |          |
|------------------|------------------------------|--------------------------------------|----------------------|------|---------------------|----------|
|                  | r arameter                   | rest conditions                      | Min.                 | Тур. | Max.                | Onic     |
| t <sub>RES</sub> | Resolution                   |                                      | $\frac{12}{f_{OSC}}$ |      |                     | second   |
| f <sub>IN</sub>  | Input Frequency on TIMER Pin |                                      |                      |      | $\frac{f_{OSC}}{8}$ | MHz      |
| t <sub>W</sub>   | Pulse Width at TIMER Pin     | $V_{DD} \ge 3V$<br>$V_{DD} \ge 4.5V$ | 1<br>125             |      |                     | μs<br>ns |

### PSS ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwhise specified})$ 

| Symbol           | Parameter             | Test Conditions                                                     | Value           |      |                 | Unit |
|------------------|-----------------------|---------------------------------------------------------------------|-----------------|------|-----------------|------|
| Cymbol           |                       |                                                                     | Min.            | Тур. | Max.            | onne |
| V <sub>PSS</sub> | PSS pin Input Voltage |                                                                     | V <sub>SS</sub> |      | V <sub>DD</sub> | V    |
| I <sub>PSS</sub> | PSS pin Input Current | PSS RUN<br>PSS STOP<br>V <sub>PSS</sub> = 5V, T <sub>A</sub> = 25°C |                 |      | 350<br>1        | μΑ   |

#### LCD ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwise specified})$ 

| Symbol           | Parameter                        | Test Conditions                              | Value |      |      | Unit |
|------------------|----------------------------------|----------------------------------------------|-------|------|------|------|
| Gymbol           | i didineter                      | resconditions                                | Min.  | Тур. | Max. | onit |
| f <sub>FR</sub>  | Frame Frequency                  | 1/4 Duty<br>f <sub>OSC</sub> = 1, 2, 4, 8MHz | 16    |      | 128  | Hz   |
| V <sub>OS</sub>  | DC Offset Voltage <sup>(1)</sup> | $V_{LCD} = V_{DD}$ , no load                 |       |      | 50   | mV   |
| V <sub>OH</sub>  | COM High Level, Output Voltage   | $I = 100 \mu A V_{LCD} = 5V$                 | 4.5V  |      |      | V    |
| Vol              | COM Low Level, Output Voltage    | $I = 100 \mu A V_{LCD} = 5V$                 |       |      | 0.5V | V    |
| V <sub>OH</sub>  | SEG High Level, Output Voltage   | $I = 50\mu A V_{LCD} = 5V$                   | 4.5V  |      |      | V    |
| V <sub>OL</sub>  | SEG Low Level, Output Voltage    | $I = 50\mu A V_{LCD} = 5V$                   |       |      | 0.5V | V    |
| V <sub>LCD</sub> | Display Voltage                  | Note 2                                       | 3     |      | 10   | V    |

Notes :

1. The DC offset voltage refers to all segment and common outputs. It is the difference between the measured voltage value and nominal value for every voltage level. Ri of voltage meter must be greater than or equal to  $100M\Omega$ .

2. An external resistances network is required when  $V_{\text{LCD}} \leq 4.5 \text{V}.$ 



## PACKAGE MECHANICAL DATA

#### Figure 3. ST62E40 80 Pin Ceramic Quad Flat Package with Window



## **ORDERING INFORMATION TABLE**

| Sales Types | Temperature Range   | Package  |
|-------------|---------------------|----------|
| ST62E40G1   | tested at 25°C only | CQFP80-W |
| ST62T40Q6   | -40 to + 85°C       | PQFP80   |



NOTES:





# 8-BIT HCMOS MCU WITH LCD DRIVER, AND A/D CONVERTER

- 3 to 6V supply operating range
- 8.4MHz Maximum Clock Frequency
- -40 to +85°C Operating Temperature Range
- Run, Wait & Stop Modes
- 5 different interrupt vectors
- Look-up table capability in ROM
- User ROM: 7948 bytes
   Data RAM: 128 bytes
   LCD RAM: 24 bytes
- PQFP64 package
- 10 fully software programmable I/O as:
   Input with/without pull-up resistor
  - Input with interrupt generation
  - Open-Drain or Push-pull outputs
  - Analog Inputs (6 pins)
- 4 I/O lines can sink up to 20mA for direct LED or TRIAC driving and have SPI alternate functions
- 8-bit counter with 7-bit programmable prescaler
- Software activated digital watchdog
- 8-bit A/D converter with up to 6 analog inputs
- 8-bit synchronous Serial Peripheral Interface (SPI)
- LCD driver with 40 segment outputs, 4 backplane outputs and selectable duty cycle for up to 160 LCD segments direct driving
- One external not maskable interrupt
- 9 powerful addressing modes
- The accumulator, the X, Y, V & W registers, the port and peripherals data & control registers are addressed in the data space as RAM locations.
- The ST62E42 is the EPROM version, ST62T42 is the OTP version
- Development tool: ST6242-EMU connected via RS232 to an MS-DOS Personal Computer



April 1995

## ST6242



## Figure 1. 64 Pin Quad Flat Pack (QFP) Package Pinout

#### **ST6242 Pin Description**

| Pin<br>number | Pin<br>name          | Pin<br>number | Pin<br>name             | Pin<br>number | Pin<br>name | Pin<br>number | Pin<br>name |
|---------------|----------------------|---------------|-------------------------|---------------|-------------|---------------|-------------|
| 1             | S45                  | 17            | VDD                     | 33            | S13         | 49            | S29         |
| 2             | S46                  | 18            | V <sub>SS</sub>         | 34            | S14         | 50            | S30         |
| 3             | S47                  | 19            | RESET                   | 35            | S15         | 51            | S31         |
| 4             | S48                  | 29            | OSCout                  | 36            | S16         | 52            | S32         |
| 5             | COM4                 | 21            | OSCin                   | 37            | S17         | 53            | S33         |
| 6             | COM3                 | 22            | NMI                     | 38            | S18         | 54            | S34         |
| 7             | COM2                 | 23            | PB7/Sout <sup>(1)</sup> | 39            | S19         | 55            | S35         |
| 8             | COM1                 | 24            | PB6/Sin <sup>(1)</sup>  | 40            | S20         | 56            | S36         |
| 9             | VLCD1/3              | 25            | PB5/SCL <sup>(1)</sup>  | 41            | S21         | 57            | S37         |
| 10            | VLCD2/3              | 26            | PB4 <sup>(1)</sup>      | 42            | S22         | 58            | S38         |
| 11            | VLCD                 | 27            | PB3/Ain                 | 43            | S23         | 59            | S39         |
| 12            | PA7/Ain              | 28            | PB2/Ain                 | 44            | S24         | 60            | S40         |
| 13            | PA6/Ain              | 29            | S9                      | 45            | S25         | 61            | S41         |
| 14            | PA5/Ain              | 30            | S10                     | 46            | S26         | 62            | S42         |
| 15            | PA4/Ain              | 31            | S11                     | 47            | S27         | 63            | S43         |
| 16            | TEST/V <sub>PP</sub> | 32            | S12                     | 48            | S28         | 64            | S44         |

Note 1: 20mA SINK



#### **GENERAL DESCRIPTION**

The ST6242 microcontroller is a member of the 8-bit HCMOS ST62xx family, a series of devices oriented to low-medium complexity applications. All ST62xx members are based on a building block approach: a common core is associated with a combination of on-chip peripherals (macrocells). The macrocells of the ST6242 are: a high performance LCD controller/driver with 40 segment outputs and 4 backplanes able to drive up to 160 segments. A Timer peripheral including an 8-bit counter with a 7-bit software programmable prescaler (Timer), the digital watchdog timer (DWD), an 8-bit A/D Converter with up to 6 analog inputs, a Power Supply Supervisor and an 8-bit synchronous Serial Peripheral Interface (SPI). Thanks to these peripherals the ST6242 is well suited for general purpose, automotive, security, appliance and industrial applications. The ST62E42 EPROM version is available for prototypes and low-volume production, an OTP version is also available (see separate datasheet).





Note: Ain = Analog Input



### ST6242

#### PIN DESCRIPTION

 $V_{DD}$  and  $V_{SS}.$  Power is supplied to the MCU using these two pins.  $V_{DD}$  is power and  $V_{SS}$  is the ground connection.

**OSCin and OSCout**. These pins are internally connected with the on-chip oscillator circuit. A quartz crystal or a ceramic resonator can be connected between these two pins in order to allow the correct operation of the MCU with various stability/cost trade-offs. OSCin is the input pin, OSCout is the output pin. An external clock signal can be applied to OSCin.

**RESET.** The active low **RESET** pin is used to restart the microcontroller at the beginning of its program. The **RESET** pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TEST.** The TEST must be held at  $V_{SS}$  for normal operation (an internal pull-down resistor selects normal operating mode if TEST pin is not connected).

**NMI.** The NMI pin provides the capability for asynchronous applying an external top priority interrupt to the MCU. This pin is falling edge sensitive. The NMI pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**PA4-PA7.** These 4 lines are organized as one I/O port (A). Each line may be configured under software control as an input with or without pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output or as analog input for the A/D converter. Port A has a 5mA drive capability in output mode.

**PB0-PB3,PB4-PB7.** These 6 lines are organized as one I/O port (B). Each line may be configured under software control as an input with or without internal pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output. PB2-PB3 can be programmed as analog inputs for the A/D converter while PB4-PB7 can also sink 20mA for direct LED driving. PB5-PB7 can also be used as respectively Clock, Data in and Data out pins for the on-chip SPI to carry the synchronous serial I/O signals.

**COM1-COM4.** These 4 pins are the LCD peripheral common outputs. They are the outputs of the onchip backplane voltage generator which is used for multiplexing the 40 LCD lines allowing up to 160 segments to be driven.

**S9-S48.** These pins are the 40 LCD peripheral driver outputs of ST6242. Segments S1-S8 are not connected to any pin.

**VLCD.** Display voltage supply. It determines the high voltage level on COM1-COM4 and S9-S48 pins.

**VLCD1/3, VLCD2/3.** Resistor network nodes for determining the intermediate display voltage levels on COM1-COM4 and S9-S48 pins during multiplex operation.



#### ST62xx CORE

The core of the ST62xx Family is implemented independently from the I/O or memory configuration. Consequently, it can be treated as an independent central processor communicating with I/O and memory via internal addresses, data, and control busses. The in-core communication is arranged as shown in Figure 3; the controller being externally linked to both the reset and the oscillator, while the core is linked to the dedicated on-chip macrocells peripherals via the serial data bus and indirectly for interrupt purposes through the control registers.

#### Registers

The ST62xx Family core has six registers and three pairs of flags available to the programmer. They are shown in Figure 4 and are explained in the following paragraphs.

Accumulator (A). The accumulator is an 8-bit general purpose register used in all arithmetic calculations, logical operations, and data manipulations. The accumulator is addressed in the data space as RAM location at address FFh. Accordingly, the ST62xx instruction set can use the accumulator as any other register of the data space.



#### Figure 4. ST62xx Core Programming Model



#### Figure 3.ST62xx Core Block Diagram



#### ST62xx CORE (Continued)

**Indirect Registers (X, Y).** These two indirect registers are used as pointers to memory locations in the data space. They are used in the register-indirect addressing mode. These registers can be addressed in the data space as RAM locations at addresses 80h (X) and 81h (Y). They can also be accessed with the direct, short direct, or bit direct addressing modes. Accordingly, the ST62xx instruction set can use the indirect registers as any other register of the data space.

**Short Direct Registers (V, W).** These two registers are used to save one byte in short direct addressing mode. These registers can be addressed in the data space as RAM locations at addresses 82h (V) and 83h (W). They can also be accessed with the direct and bit direct addressing modes. Accordingly, the ST62xx instruction set can use the short direct registers as any other register of the data space.

#### **Program Counter (PC)**

The program counter is a 12-bit register that contains the address of the next ROM location to be processed by the core. This ROM location may be an opcode, an operand, or an address of operand. The 12-bit length allows the direct addressing of 4096 bytes in the program space. Nevertheless, if the program space contains more than 4096 locations, as for the ST6242, the further program space can be addressed by using the Program ROM Page register.

The PC value is incremented after it is read from the address of the current instruction. To execute relative jumps the PC and the offset are shifted through the ALU, where they will be added, and the result is shifted back into the PC. The program counter can be changed in the following ways:

| - JP (Jump) instruction        | PC=Jump address     |
|--------------------------------|---------------------|
| - CALL instruction             | PC=Call address     |
| - Relative Branch instructions | $PC=PC \pm offset$  |
| - Interrupt                    | PC=Interrupt vector |
| - Reset                        | PC=Reset vector     |
| - RET & RETI instructions .    | PC=Pop (stack)      |
| - Normal instruction           | PC=PC+1             |

### Flags (C, Z)

The ST62xx core includes three pairs of flags that correspond to 3 different modes: normal mode, interrupt mode and Non-Maskable Interrupt-Mode. Each pair consists of a CARRY flag and a ZERO flag. One pair (CN, ZN) is used during normal operation, one pair is used during the interrupt mode (CI, ZI) and one is used during the not-maskable interrupt mode (CNMI, ZNMI).

The ST62xx core uses the pair of flags that correspond to the actual mode: as soon as an interrupt (resp. a Non-Maskable-Interrupt) is generated, the ST62xx core uses the interrupt flags (resp. the NMI flags) instead of the normal flags. When the RETI instruction is executed, the normal flags (resp. the interrupt flags) are restored if the MCU was in the normal mode (resp. in the interrupt mode) before the interrupt. It should be observed that each flag set can only be addressed in its own mode (Notmaskable interrupt, normal interrupt or main mode). The flags are not cleared during the context switching and so remain in the state they were at the exit of the last mode switch.

The Carry flag is set when a carry or a borrow occurs during arithmetic operations, otherwise it is cleared. The Carry flag is also set to the value of the bit tested in a bit test instruction, and participates in the rotate left instruction.

The Zero flag is set if the result of the last arithmetic or logical operation was equal to zero, otherwise it is cleared.

The switching between the three sets of Flags is automatically performed when an NMI, an interrupt or a RETI instruction occurs. As the NMI mode is automatically selected after the reset of the MCU, the ST62xx core uses at first the NMI flags.



#### ST62xx CORE (Continued)

#### Stack

The ST62xx core includes a true LIFO hardware stack that eliminates the need for a stack pointer. The stack consists of six separate 12-bit RAM locations that do not belong to the data space RAM area. When a subroutine call (or interrupt request) occurs, the contents of each level is shifted into the next level while the content of the PC is shifted into the first level (the value of the sixth level will be lost). When a subroutine or interrupt return occurs (RET or RETI instructions), the first level register is shifted back into the PC and the value of each level is popped back into the previous level. These two operating modes are described in Figure 5. Since the accumulator, as all other data space registers, is not stored in the stack, the handling of these registers should be performed inside the subroutine. The stack pointer will remain in its deepest position if more than 6 calls or interrupts are executed, so that the last return address will be lost. It will also remain in its highest position if the stack is empty and a RET or RETI is executed. In this case the next instruction will be executed.

#### Figure 5. Stack Operation



#### **MEMORY SPACES**

The MCU operates in three different memory spaces: program space, data space, and stack space. A description of these spaces is shown in the following figures.

#### **Program Space**

The program space is physically implemented in the ROM memory and includes all the instructions that are to be executed, as well as the data required for the immediate addressing mode instructions, the reserved test area and the user vectors. It is addressed by the 12-bit Program Counter register (PC register) and so the ST62xx core can directly address up to 4K bytes of Program Space. Nevertheless, the Program Space can be extended by the addition of 2Kbyte ROM banks as it is shown in the following figure in which the ST6242 8Kbyte memory is described.

## Figure 6. ST6242 8Kbytes Program Space Addressing Description





#### Figure 7. ST62xx Memory Addressing Description Diagram



These banks are addressed in the 000h-7FFh locations of the Program Space by the Program Counter and by writing the appropriate code in the Program ROM Page Register (PRPR register) located at address CAh of the Data Space. Because interrupts and common subroutines should be available all the time, only the lower 2K byte of the 4K program space are bank switched while the upper 2K byte can be seen as static page. Table 2 gives the different codes that allow the selection of the corresponding banks. Note that, from the memory point of view, Page 1 and the Static Page represent the same physical memory: it is only two different ways of addressing the same locations. On the ST6242 a total of 8192 bytes of ROM have been implemented; 7948 are available as user ROM while 244 are reserved for SGS-THOMSON test purposes.

Table 1. ST6242 Program ROM Memory Map

| ROM Page           | Device Address                                                                         | Description                                                                            |
|--------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
| Page 0             | 0000h-007Fh<br>0080h-07FFh                                                             | Reserved<br>User ROM                                                                   |
| Page 1<br>"STATIC" | 0800h-0F9Fh<br>0FA0h-0FEFh<br>0FF0h-0FF7h<br>0FF8h-0FFBh<br>0FFCh-0FFDh<br>0FFEh-0FFFh | User ROM<br>Reserved<br>Interrupt<br>Vectors<br>Reserved<br>NMI Vector<br>Reset Vector |
| Page 2             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                   |
| Page 3             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                   |



#### **Data Space**

The instruction set of the ST62xx core operates on a specific space, named Data Space, that contains all the data necessary for the processing of the program. The Data Space allows the addressing of RAM memory, ST62xx core/peripheral registers, and read-only data such as constants and look-up tables.

#### Data ROM

All the read-only data is physically implemented in the ROM memory in which the Program Space is also implemented. The ROM memory contains consequently the program to be executed, the constants and the look-up tables needed for the program.

The locations of Data Space in which the different constants and look-up tables are addressed by the ST62xx core can be considered as being a 64-byte window through which it is possible to access to the read-only data stored in the ROM memory.

#### **Data RAM Addressing**

The ST6242 offers 128 bytes of data RAM memory. 64 bytes of RAM are directly addressed in data space in the range 084h-0BFh (static space). The additional RAM is addressed using the banks of 64 bytes located between addresses 00h and 3Fh.

Additionally 24 bytes of RAM devoted to LCD dat are available from E0h to F7h and are not banked.

#### Stack Space

The stack space consists of six 12 bit registers that are used for stacking subroutine and interrupt return addresses plus the current program counter register.

| DATA RAM/EEPROM BANK AREA  | 000h  |
|----------------------------|-------|
|                            | 03Fh  |
|                            | 040h  |
| DATA ROM WINDOW AREA       |       |
|                            | 07Fh  |
| X REGISTER                 | 080h  |
| Y REGISTER                 | 081h  |
| V REGISTER                 | 082h  |
| W REGISTER                 | 083h  |
| DATA RAM 60 BYTES          | 084h  |
|                            | 0BFh  |
| PORT A DATA REGISTER       | 0C0h  |
|                            | 0C1h  |
| SPI INT. DISABLE REGISTER  | 0C2h* |
| RESERVED                   | 0C3h  |
| PORT A DIRECTION REGISTER  | 0C4h  |
| PORT B DIRECTION REGISTER  | 0C5h  |
| RESERVED                   | 0C6h  |
| RESERVED                   | 0C7h  |
| INTERRUPT OPTION REGISTER  | 0C8h* |
| DATAROM WINDOW REGISTER    | 0C9h* |
| PROGRAM ROM PAGE REGISTER  | 0CAh* |
| DATA RAM PAGE REGISTER     | 0CBh* |
| PORT A OPTION REGISTER     | 0CCh  |
| RESERVED                   | 0CDh  |
| PORT B OPTION REGISTER     | 0CEh  |
| RESERVED                   | 0CFh  |
| A/D DATAREGISTER           | 0D0h  |
| A/D CONTROLREGISTER        | 0D1h  |
| TIMER PRESCALER REGISTER   | 0D2h  |
| TIMER COUNTER REGISTER     | 0D3h  |
| TIMER STATUS/CONT REGISTER | 0D4h  |
|                            | 0D5h  |
| RESERVED                   | 0D6h  |
|                            | 0D7h  |
| WATCHDOG REGISTER          | 0D8h  |
|                            | 0D9h  |
| RESERVED                   | 0DAh  |
|                            | 0DBh  |
| LCD MODE CONTROL REGISTER  | 0DCh  |
| SPI DATA REGISTER          | 0DDh  |
| RESERVED                   | 0DEh  |
| WRITE: 40h                 | 0DFh  |
|                            | 0E0h  |
| LCD RAM                    | 0E0h  |
|                            | 0F8h  |
| DATA RAM 7 BYTES           | 0FEh  |
| ACCUMULATOR                | 0FFh  |
| ACCONDECTOR                |       |
|                            |       |

\* WRITE ONLY REGISTER



SGS-THOMSON MICROFLECTRONICS

#### Program ROM Page Register (PRPR)

The PRPR register can be addressed like a RAM location in the Data Space at the address CAh; nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to select the 2-Kbyte ROM bank of the Program Space that will be addressed. The number of the page has to be loaded in the PRPR register. Refer to the Program Space description for additional information concerning the use of this register. The PRPR register is not modified when an interrupt or a subroutine occurs.

Care is required when handling the PRPR register as it is write only. For this reason, it is not allowed to change the PRPR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. This operation may be necessary if common routines and interrupt service routines take more than 2K bytes; in this case it could be necessary to divide the interrupt service routine into a (minor) part in the static page (start and end) and to a second (major) part in one of the dynamic pages. If it is impossible to avoid the writing of this register in interrupt service routines, an image of this register must be saved in a RAM location, and each time the program writes to the PRPR it must write also to the image register. The image register must be written before PRPR, so if an interrupt occurs between the two instructions the PRPR is not affected.

#### Figure 9. Program ROM Page Register



D7-D2. These bits are not used.

**PRPR1-PRPR0.** These are the program ROM banking bits and the value loaded selects the corresponding page to be addressed in the lower part of the 4K program address space as specified in Table 2.

## Table 2. ST6242 8Kbytes Program ROM PageRegister Coding

| PRPR1 | PRPR0 | PC bit 11 | Memory Page          |
|-------|-------|-----------|----------------------|
| Х     | Х     | 1         | Static Page (Page1)  |
| 0     | 0     | 0         | Page 0               |
| 0     | 1     | 0         | Page 1 (Static Page) |
| 1     | 0     | 0         | Page 2               |
| 1     | 1     | 0         | Page 3               |

This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

#### Note:

Only the lower part of address space is bank switched because interrupt vectors and common subroutines should be available at all times. The reason of this structure is due to the fact that it is not possible to jump from one dynamic page to another except by jumping back to the static page, changing contents of PRPR, and then jumping to a different dynamic page.



#### Data Window register (DWR)

The Data ROM window is located from address 040h to address 7Fh in the Data space. It allows the direct reading of 64 consecutive bytes located anywhere in the ROM memory between the addresses 0000h and 1FFFh. All the bytes of the ROM memory can be used to store either instructions or read-only data. Indeed, the window can be moved by step of 64 bytes along the ROM memory in writing the appropriate code in the Write-only Data Window register (DWR register, location C9h).

The DWR register can be addressed like a RAM location in the Data Space at the address C9h, nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to move the 64-byte read-only data window (from the 40h address to 7Fh address of the Data Space) up and down the ROM memory of the MCU in steps of 64 bytes. The effective address of the byte to be read as a data in the ROM memory is obtained by the concatenation of the 6 least significant bits of the register address given in the instruction (as least significant bits) and the content of the DWR register (as most significant bits, see Figure 10). So when addressing location 40h of dataspace, and 0 is loaded in the DWR register, the phisycal addressed location in ROM is 00h. The DWR register is not cleared at reset, therefore it must be written to before the first access to the Data ROM window area.



#### Figure 11. Data ROM Window Register

DWR6-DWR0. These are the Data ROM Window bits that correspond to the upper bits of the data ROM space.

#### This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

Note: Care is required when handling the DWR register as it is write only. For this reason, it is not allowed to change the DWR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. If it is impossible to avoid the writing of this register in the interrupt service routine, an image of this register must be saved in a RAM location, and each time the program writes to the DWR it must write also to the image register. The image register must be written first, so if an interrupt occurs between the two instructions the DWR is not affected.





. MICROFLECTRONICS

D7. This bit is not used.

#### Data RAM Bank Register (DRBR)

The selection of the bank is made by programming the Data RAM Bank Switch register (DRBR register) located at address CBh of the Data Space. The number of the selected bank is equal to the bit content of the DRBR register. In this way each bank of RAM can be selected 64 bytes at a time. No more than one bank should be set at a time.

The DRBR register can be addressed like a RAM location in the Data Space at the address CBh; nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to select the desired 64-byte RAM bank of the Data Space. The number of the bank has to be loaded in the DRBR register and the instruction has to point to the selected location as if it was in bank 0 (from 00h address to 3Fh address). This register is not cleared during the MCU initialization, therefore it must be written before the first access to the Data Space bank region. Refer to the Data Space description for additional information. The DRBR register is not modified when a interrupt or a subroutine occurs.

The following table 3 summarizes how to set the data RAM bank register in order to select the various banks or pages.

#### Table 3. Data RAM Register Set-up

| DRBR Value | Selection  |
|------------|------------|
| 08h        | RAM Page 1 |

#### Figure 12. Data RAM Bank Register



D7-D4. These bits are not used.

**DRBR3.** This bit, when set, will select the RAM page.

D2-D0. These bits are not used.

This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

#### Notes:

Care is required when handling the DRBR register as it is write only. For this reason, it is not allowed to change the DRBR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. If it is impossible to avoid the writing of this register in interrupt service routine, an image of this register must be saved in a RAM location, and each time the program writes to DRBR it must write also to the image register. The image register must be written first, so if an interrupt occurs between the two instructions the DRBR is not affected.

In DRBR Register, *only 1 bit must be set.* Otherwise two or more pages are enabled in parallel, producing errors.



#### **TEST MODE**

For normal operation the TEST pin must be held low. An on-chip  $100k\Omega$  pull-down resistor is internally connected to the TEST pin.

#### **INTERRUPTS**

The ST62xx core can manage 4 different maskable interrupt sources, plus one non-maskable interrupt source (top priority level interrupt). Each source is associated with a particular interrupt vector that contains a Jump instruction to the related interrupt service routine. Each vector is located in the Program Space at a particular address.

When a source provides an interrupt request, and the request processing is also enabled by the ST62xx core, then the PC register is loaded with the address of the interrupt vector (i.e. of the Jump instruction). Finally, the PC is loaded with the address of the Jump instruction and the interrupt routine is processed.

The ST6242 microcontroller has six different interrupt sources associated to different interrupt vectors as described in Table 4.

#### Table 4. Interrupt Vectors - Sources Relationship

| Interrupt<br>Source | Associated Vector                     | Vector<br>Address |
|---------------------|---------------------------------------|-------------------|
| NMI Pins            | NMI Pins Interrupt Vector #0<br>(NMI) |                   |
| SPI<br>Peripheral   | Interrupt Vector #1                   | (FF6h-FF7h)       |
| Port A & B<br>Pins  | Interrupt Vector #2                   | (FF4h-FF5h)       |
| TIMER               | Interrupt Vector #3                   | (FF2h-FF3h)       |
| ADC<br>Peripheral   | Interrupt Vector #4                   | (FF0h-FF1h)       |

#### **Interrupts Vectors Description**

The ST62xx core includes 5 different interrupt vectors in order to branch to 5 different interrupt routines in the static page of the Program Space:

- The interrupt vector associated with the nonmaskable interrupt source is named interrupt vector #0. It is located at addresses FFCh,FFDh in the Program Space. On ST6242 this vector is associated with the external falling edge sensitive interrupt pin (NMI). An on-chip 100kΩ pull-up resistor is internally connected to the NMI pin.
- The interrupt vector located at the addresses FF6h, FF7h is named interrupt vector #1. It is associated with SPI peripheral and can be programmed by software to generate an interrupt request after the falling edge or low level of the eighth external clock pulse according to the code loaded in the Interrupt Option Register (IOR).
- The interrupt vector located at the addresses FF4h, FF5h is named interrupt vector #2. It is associated with Port A and B pins and can be programmed by software either in the falling edge detection mode or in the rising edge detection mode according to the code loaded in the Interrupt Option Register (IOR).
- The interrupt vector located at the addresses FF2h, FF3h is named interrupt vector #3. It is associated with Timer.
- The interrupt vector located at the addresses FF0h, FF1h is named interrupt vector #4. It is associated with the A/D converter peripheral.

All the on-chip peripherals (refer to their descriptions for further details) have an interrupt request flag bit (TMZ for timer, EOC for A/D, etc.), this bit is set to one when the device wants to generate an interrupt request and a mask bit (ETI for timer, EAI for A/D, etc.) that must be set to one to allow the transfer of the flag bit to the Core.

#### **Interrupt Priority**

The non-maskable interrupt request has the highest priority and can interrupt any other interrupt routines at any time, nevertheless the four other interrupts cannot interrupt each other. If more than one interrupt request is pending, they are processed by the ST62xx core according to their priority level: vector #1 has the higher priority while vector #4 the lower. The priority of each interrupt source is fixed.



#### **INTERRUPTS** (Continued)

#### Interrupt Option Register

The Interrupt Option Register (IOR register, location C8h) is used to enable/disable the individual interrupt sources and to select the operating mode of the external interrupt inputs. This register can be addressed in the Data Space as RAM location at the address C8h, nevertheless it is a write-only register that cannot be accessed with single-bit operations. The operating modes of the external interrupt inputs associated to interrupt vectors #1 and #2 are selected through bits 5 and 6 of the IOR register.

#### Figure 13. Interrupt Option Register



D7. This bit is not used.

**LES.** Level/Edge Selection Bit. When this bit is set to one, the interrupt #1 (SPI) is low level sensitive, when cleared to zero the negative edge sensitive interrupt is selected.

**ESB.** Edge Selection Bit. When this bit is set to one, the interrupt #2 (Port A & B lines) is positive edge sensitive, when cleared to zero the negative edge sensitive interrupt is selected.

**GEN.** Global Enable Interrupt. When this bit is set to one, all the interrupts are enabled. When this bit is cleared to zero all the interrupts (but NMI) are disabled.

This register is cleared on reset.

| Table 5 | . Interrupt | Option | Register | Description |
|---------|-------------|--------|----------|-------------|
|---------|-------------|--------|----------|-------------|

| GEN    | SET      | Enable all interrupts                         |
|--------|----------|-----------------------------------------------|
| GLIN   | CLEARED  | Disable all interrupts                        |
| ESB    | SET      | Rising edge mode on<br>interrupt input #2     |
|        | CLEARED  | Falling edge mode on<br>interrupt input #2    |
| LES    | SET      | Level-sensitive mode on<br>interrupt input #1 |
|        | CLEARED  | Falling edge mode on<br>interrupt input #1    |
| OTHERS | NOT USED |                                               |

#### **External Interrupts Operating Modes**

The NMI interrupt is associated to the NMI pin of the ST6242. The two interrupt requests are "ORed". The highest priority interrupt request will be generated by a falling edge applied to the NMI pin. The NMI interrupt pin signal is latched and is automatically reset by the core at the beginning of the non-maskable interrupt service routine. An on-chip pull-up resistor and a schmitt trigger is available with the NMI pin.

The two interrupt sources associated with the falling/rising edge mode of the external interrupt pins (SPI vector #1, Ports A and B vector #2,) are connected to two internallatches. Each latch is set when a falling/rising edge occurs and is cleared when the associated interrupt routine is started. So, the occurrence of an external interrupt request is stored: a second interrupt, that occurs during the processing of the first one, will be processed as soon as the first one has been finished (if there is not an higher priority interrupt request). If more than one interrupt occurs during the processing of the first one, these other interrupt requests will be lost.

The storage of the interrupt requests is not available in the level sensitive detection mode. To be taken into account, the low level must be present on the interrupt pin when the core samples the line after the execution of the instructions.

During the end of each instruction the core tests the interrupt lines and if there is an interrupt request the nextinstruction is not executed and the related interrupt routine is executed.



#### **INTERRUPTS** (Continued)

Interrupt Procedure. The interrupt procedure is very similar to a call procedure, indeed the user can consider the interrupt as an asynchronous call procedure. As this is an asynchronous event the user does not know about the context and the time at which it occurred. As a result the user should save all the data space registers which will be used inside the interrupt routines. There are separate sets of processor flags for normal, interrupt and non-maskable interrupt modes which are automatically switched and so these do not need to be saved.

The following list summarizes the interrupt procedure:

- ST62xx actions
- Interrupt detection
- The flags C and Z of the main routine are exchanged with the flags C and Z of the interrupt routine (or the NMI flags)
- The value of the PC is stored in the first level of the stack
- The normal interrupt lines are inhibited (NMI still active)
- First internal latch is cleared
- The related interrupt vector is loaded in the PC. User actions
- User selected registers are saved inside the interrupt service routine (normally on a software stack)
- The source of the interrupt is found by polling (if more than one source is associated to the same vector) the interrupt flag of the source.
- Interrupt servicing
- Return from interrupt (RETI)
- ST62xx actions
- Automatically the ST62xx core switches back to the normal flags (or the interrupt flags) and pops the previous PC value from the stack

The interrupt routine begins usually by the identification of the device that has generated the interrupt request (by polling). The user should save the registers which are used inside the interrupt routine (that holds relevant data) into a software stack. After the RETI instruction execution, the core carries out the previous actions and the main routine can continue.



#### Figure 14. Interrupt Processing Flow-Chart

**WARNING.** GEN is the global enable for all interrupts except NMI. If this bit is cleared, the NMI interrupt is accepted when the ST62xx core is in the normal RUN Mode.

If the ST62xx core is in STOP or WAIT Mode, the NMI is not accepted as a restart is disabled. This state can only be finished by a reset (from the Watchdog or an external Reset Signal).

As a consequence the NMI can be masked in STOP and WAIT modes, but not in RUN mode.



**INTERRUPTS** (Continued)

#### Interrupt request and mask bits

### Interrupt Option Register, IOR Location C8h

- GEN. If this bit is set, all the ST62xx interrupts are enabled, if reset all interrupts are disabled (including the NMI).
- ESB. If this bit is set, all the input lines associated to interrupt vector #2 are rising edge sensitive, if reset they are falling edge sensitive.
- LES. If this bit is set, all the inputs lines associated to interrupt vector #1 are low level sensitive, if reset they are falling edge sensitive.

All other bits in this register are not used.

## Timer Peripherals, TSCR1 and TSCR2 registers, locations D4h and D7h

- TMZ. A low-to-high transition indicates that the timer count register has decremented to zero. This means that an interrupt request can be generated in relation to the state of ETI bit.
- ETI. This bit, when set, enables the timer interrupt request.

## A/D Converter Peripheral, ADCR register location D0h

- EOC. This read only bit indicates when a conversion has been completed, by going to one. An interrupt request can be generated in relation to the state of EAI bit.
- EAI. This bit, when set, enables the A/D converter interrupt request.



Figure 15. ST6242 Interrupt Circuit Diagram



#### RESET

The ST6242 can be reset in three ways: by the external reset input (RESET) tied low, by power-on reset and by the digital watchdog/timer peripheral.

#### **RESET Input**

The RESET pin can be connected to a device of the application board in order to restart the MCU during its operation. The activation of the RESET pin may occur in the RUN, WAIT or STOP mode. This input has to be used to reset the MCU internal state and provide a correct start-up procedure. The pin is active low. The internal reset signal is generated by adding a delay to the external signal. Therefore even short pulses at the RESET pin will be accepted. This feature is valid providing that  $V_{DD}$ has finished its rising phase and the oscillator is correctly running (normal RUN or WAIT modes).

If RESET activation occurs in the RUN or Wait mode, the MCU is configured in the Reset mode for as long as the signal of the RESET pin is low. The processing of the program is stopped (in RUN mode only) and the Input/Outputs are in the Highimpedance state with pull-up resistors switched on. As soon as the level on the RESET pin becomes high, the initialization sequence is executed.

If a RESET pin activation occurs in the STOP mode, the oscillator starts and all the inputs/outputs are configured in the High-impedance state with pull-up resistors switched on for as long as the level on the RESET pin remains low. When the level of the RESET pin becomes high, a delay is generated by the ST62xx core to wait that the oscillator becomes completely stabilized. Then, the initialization sequence is started.

#### Power-On Reset (POR)

The function of the POR consists in waking up the MCU during the power-on sequence. At the beginning of this sequence, the MCU is configured in the Reset state: every Input/Output port is configured in the input mode (High-impedance state with pullup) and no instruction is executed. When the power supply voltage becomes sufficient, the oscillator starts to operate, nevertheless the ST62xx core generates a delay to allow the oscillator to be completely stabilized before the execution of the first instruction. The initialization sequence is then executed.

Internal circuitry generates a Reset pulse when  $V_{DD}$  is switched on. In the case of fast rising  $V_{DD}$  (transition time  $\leq 100 \mu s$ ), this reset pulse starts the internal reset procedure without the need of external components at the RESET pin. In cases of slowly or non monotonously rising  $V_{DD}$ , an external reset signal must be provided for a proper reset of the MCU.

For as long as the reset pin is kept at the low level, the processor remains in the reset state. The reset will be released after the voltage at the reset pin reaches the high level.

#### Note:

To have a correct ST62xx start-up, the user should take care that the reset input does not change to the high level before the  $V_{DD}$  level is sufficient to allow MCU operation at the chosen frequency (see recommended operating conditions).

An on-chip counter circuit provides a delay of 2048 oscillator cycles between the detection of the reset high level and the release of the MCU reset.

A proper reset signal for slow rising V<sub>DD</sub>, i.e. the required delay between reaching sufficient operating voltage and the reset input changing to a high level, can be generally provided by an external capacitor connected between the RESET pin and V<sub>SS</sub>.



## ST6242

#### **RESET** (Continued)

#### Watchdog Reset

The ST6242 provides an on-chip watchdog function in order to provide a graceful recovery from a software upset. If the watchdog register is not refreshed, preventing the end-of-count being reached, an internal circuit pulls down the RESET pin. The MCU will enter the reset state as soon as the voltage at RESET pin reaches the related low level. This also resets the watchdog which subsequently turns off the pull-down and activates the pull-up device at the RESET pin. This causes the positive transition at the RESET pin and terminates the reset state.

#### Figure 16. Reset Circuit



#### **Application Notes**

An external resistor between V<sub>DD</sub> and reset pin is not required because an internal pull-up device is provided. If the user prefers, for any reason, to add an external pull-up resistor its value must comply with the Rmin value defined in Figure 17. If the value is lower than Rmin, the on-chip watchdog pull-down transistor might not be able to pull-down the reset pin resulting in an external deactivation of the watchdog function.

The POR function operates in a dynamic manner in the way that it brings about the initialization of the MCU when it detects a dynamic rising edge of the  $V_{DD}$  voltage. The typical detected threshold is about 2 volts, but the actual value of the detected threshold depends on the way in which the  $V_{DD}$  voltage rises up. The POR device DOES NOT allow the supervision of a static rising or falling edge of the  $V_{DD}$  voltage.

#### Figure 17. External Reset Resistance





#### **RESET** (Continued)

#### Figure 18. Reset & Interrupt Processing Flow-Chart



## MCU Initialization Sequence

When a reset occurs the stack is reset to the program counter, the PC is loaded with the address of the reset vector (located in the program ROM at addresses FFEh & FFFh). A jump instruction to the beginning of the program has to be written into these locations. After a reset the interrupt mask is automatically activated so that the core is in non-maskable interrupt mode to prevent false or ghost interrupts during the restart phase. Therefore the restart routine should be terminated by a RETI instruction to switch to normal mode and enable interrupts. If no pending interrupt is present at the end of the reset routine the ST62xx will continue with the instruction after the RETI; otherwise the pending interrupt will be serviced.





#### **Table 6. Reset Configuration**

| Input/Output pins                        | Registers                                                                                                                                                                                             |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Mode with pull-up and no interrupt | All cleared but A,X,Y,V,W, data RAM, LCD RAM,<br>DWR (C9), PRPR (CA), DRBR (CB).<br>Timers prescaler and TCR are initialized respectively at<br>7F and FF. Watchdog register DWDR (D8) is set to FEh. |



#### WAIT & STOP MODES

The WAIT and STOP modes have been implemented in the ST62xx core in order to reduce the consumption of the product when the latter has no instruction to execute. These two modes are described in the following paragraphs

#### WAIT Mode

The configuration of the MCU in the WAIT mode occurs as soon as the WAIT instruction is executed. The microcontroller can also be considered as being in a "software frozen" state where the core stops processing the instructions of the routine, the contents of the RAM locations and peripheral registers are saved as long as the power supply voltage is higher than the RAM retention voltage but where the peripherals are still working.

The WAIT mode is used when the user wants to reduce the consumption of the MCU when it is in idle, while not losing count of time or monitoring of external events. The oscillator is not stopped in order to provide a clock signal to the peripherals. The timer counting may be enabled (writing the PSI bit in TSCR register) and the timer interrupt may be also enabled before entering the WAIT mode; this allows the WAIT mode to be left when timer interrupt occurs. The above explanation related to the timers applies also to the A/D converter.

If the exit from the WAIT mode is performed with a general RESET (either from the activation of the external pin or by watchdog reset) the MCU will enter a normal reset procedure as described in the RESET chapter. If an interrupt is generated during WAIT mode the MCU behavior depends on the state of the ST62xx core before the initialization of the WAIT sequence, but also of the kind of the interrupt request that is generated. This case will be described in the following paragraphs. In any case, the ST62xx core does not generate any delay after the occurrence of the interrupt because the oscillator clock is still available.

#### STOP Mode

If the Watchdog is disabled the STOP mode is available. When in STOP mode the MCU is placed in the lowest power consumption mode. In this operating mode the microcontroller can be considered as being "frozen", no instruction is executed, the oscillator is stopped, the contents of the RAM locations and peripheral registers are saved as long as the power supply voltage is higher than the RAM retention voltage, and the ST62xx core waits for the occurrence of an external interrupt request or Reset activation to output from the STOP state.

If the exit from the STOP mode is performed with a general RESET (by the activation of the external pin) the MCU will enter a normal reset procedure as described in the RESET chapter. The case of an interrupt depends on the state of the ST62xx core before the initialization of the STOP sequence and also of the kind of the interrupt request that is generated.

This case will be described in the following paragraphs. In any case, the ST62xx core generates a delay after the occurrence of the interrupt request in order to wait the complete stabilization of the oscillator before the execution of the first instruction.

#### **Exit from WAIT and STOP Modes**

The following paragraphs describe the output procedure of the ST62xx core from WAIT and STOP modes when an interrupt occurs (not a RESET). It must be noted that the restart sequence depends on the original state of the MCU (normal, interrupt or non-maskable interrupt mode) before the start of the WAIT or STOP sequence, but also of the type of the interrupt request that is generated.

**Normal Mode.** If the ST62xx core was in the main routine when the WAIT or STOP instruction has been executed, the ST62xx core outputs from the stop or wait mode as soon as any interrupt occurs; the related interrupt routine is executed and at the end of the interrupt service routine the instruction that follows the STOP or the WAIT instruction is executed if no other interrupts are pending.



#### WAIT & STOP MODES (Continued)

**Not Maskable Interrupt Mode.** If the STOP or WAIT instruction has been executed during the execution of the non-maskable interrupt routine, the ST62xxcore outputs from the stop or wait mode as soon as any interrupt occurs: the instruction that follows the STOP or the WAIT instruction is executed and the ST62xx core is still in the non-maskable interrupt mode even if another interrupt has been generated.

**Normal Interrupt Mode.** If the ST62xx core was in the interrupt mode before the initialization of the STOP or WAIT sequence, it outputs from the stop or wait mode as soon as any interrupt occurs. Nevertheless, two cases have to be considered:

- If the interrupt is a normal interrupt, the interrupt routine in which the WAIT or STOP was entered will be completed with the execution of the instruction that follows the STOP or the WAIT and the ST62xx core is still in the interrupt mode. At the end of this routine pending interrupts will be serviced in accordance to their priority.
- If the interrupt is a non-maskable interrupt, the non-maskable routine is processed at first. Then the routine in which the WAIT or STOP was entered will be completed with the execution of the instruction that follows the STOP or the WAIT and the ST62xx core remains in the normal interrupt mode.

#### Notes:

To reach the lowest power consumption the user software must take care of:

- placing the A/D converter in its power down mode by clearing the PDS bit in the A/D control register before entering the STOP instruction.
- switching off the 32kHz oscillator by clearing the oscillator start/stop bit in the 32kHz oscillator control register.
- putting the EEPROM on-chip memory in standby mode by writing 40h in EEPROM Control Register (address DFh).

The LCD Driver peripheral is automatically switched-off by the STOP instruction when the 32kHz oscillator operation is not selected.

When the watchdog has been enabled, the STOP instruction is deactivated and any attempt to execute the STOP instruction will cause an execution of a WAIT instruction.

If all the interrupt sources are disabled (including NMI if GEN="0"), the restart of the MCU can only be done by a RESET activation. The WAIT and STOP instructions are not executed if an enabled interrupt request is pending.

#### **ON-CHIP CLOCK OSCILLATOR**

The internal oscillator circuit is designed to require a minimum of external components. A crystal, a ceramic resonator, or an external signal (provided to the OSCin pin) may be used to generate a system clock with various stability/cost tradeoffs. The different clock generator options connection methods are shown in Figure 21.

One machine cycle takes 13 oscillator pulses; 12 clock pulses are needed to increment the PC while and additional 13th pulse is needed to stabilize the internal latches during memory addressing. This means that with a clock frequency of 8MHz the machine cycle is  $1.625\mu s$ .

The crystal oscillator start-up time is a function of many variables: crystal parameters (especially  $R_S$ ), oscillator load capacitance (CL), IC parameters, ambient temperature, supply voltage. It must be observed that the crystal or ceramic leads and circuit connections must be as short as possible. Typical values for CL1, CL2 are 15-22pF for a 4/8MHz crystal. The oscillator output frequency is internally divided by 13 to produce the machine cycle and by 12 to produce the Timer, the Watchdog and the A/D peripheralclock. Amachine cycle is the smallest unit needed to execute any operation (i.e., increment the program counter). An instruction may need two, four, or five machine cycles to be executed.

#### Figure 20. Crystal Parameters





## **ON-CHIP CLOCK OSCILLATOR** (Continued)

#### Figure 21. Oscillator Connection





#### **INPUT/OUTPUT PORTS**

The ST6242 microcontroller has 10 Input/Output lines that can be individually programmed either in the input mode or the output mode with the follow-ing options that can be selected by software:

- Input without pull-up and without interrupt
- Input with pull-up and with interrupt
- Input with pull-up without interrupt
- Analog inputs (PA4-PA7, PB2-PB3)
- SPI control signals (PB5-PB7)
- Push-pull output
- Standard Open drain output
- 20mA Open drain output (PB4-PB7)

The lines are organized in two ports (port A,B).

Each port occupies 3 registers in the data space. Each bit of these registers is associated with a particular line (for instance, the bits 0 of the Port A Data, Direction and Option registers are associated with the PA0 line of Port A).

The two DATA registers (DRA, DRB), are used to read the voltage level values of the lines programmed in the input mode, or to write the logic value of the signal to be output on the lines configured in the output mode. The port data registers can be read to get the effective logic levels of the pins, but they can be also written by the user software, in conjunction with the related option registers, to select the different input mode options.

Single-bit operations on I/O registers are possible but care is necessary because reading in input mode is done from I/O pins while writing will directly affect the Port data register causing an undesired change of the input configuration.

The two Data Direction registers (DDRA, DDRB) allow the selection of the data direction of each pin (input or output).

The two Option registers (ORPA, ORPB) are used to select the different port options available both in input and in output mode.

All the I/O registers can be read or written as any other RAM location of the data space, so no extra RAM cell is needed for port data storing and manipulation. During the initialization of the MCU, all the I/O registers are cleared and the input mode with pull-up/no-interrupt is selected on all the pins, thus avoiding pin conflicts.



#### Figure 22. I/O Port Block Diagram



#### INPUT/OUTPUT PORTS (Continued)

#### I/O Pin Programming

Each pin can be individually programmed as input or output with different input and output configurations.

This is achieved by writing to the relevant bit in the data (DR), data direction register (DDR) and option registers (OR). Table 7 shows all the port configurations that can be selected by user software.

#### **Input Option Description**

**Pull-up, High Impedance Option.** All the input lines can be individually programmed with or without an internal pull-up according to the codes programmed in the OR and DR registers. If the pull-up option is not selected, the input pin is in the high-impedance state.

Interrupt Option. All the input lines can be individually connected by software to the interrupt lines of the ST62xx core according to the codes programmed in the OR and DR registers. The pins of Port A and B are "ORed" and are connected to the interrupt associated to the vector #2. The interrupt modes (falling edge sensitive, rising edge sensitive) can be selected by software for each port by programming the IOR register.

**Analog Input Option.** The six PA4-PA7, PB2-PB3 pins can be configured to be analog inputs according to the codes programmed in the OR and DR registers. These analog inputs are connected to the on-chip 8-bit Analog to Digital Converter. *ONLY ONE* pin should be programmed as analog input at a time, otherwise the selected inputs will be shorted.

#### Figure 23. I/O Port Data Registers



#### Figure 24. I/O Port Data Direction Registers



#### Figure 25. I/O Port Option Registers



Note: For complete coding explanation refer to Table 7.



## **INPUT/OUTPUT PORTS** (Continued)

## Table 7. I/O Port Configuration

| DDR,<br>OR | DR | Mod<br>e | Option | Schematic                                                          |          |
|------------|----|----------|--------|--------------------------------------------------------------------|----------|
| 0          | 0  | 0        | Input  | Pull-up<br>No interrupt<br>(RESET state)                           | Data in  |
| 0          | 0  | 1        | Input  | No pull-up<br>No interrupt                                         | Data in  |
| 0          | 1  | 0        | Input  | Pull-up<br>Interrupt                                               | Data in  |
| 0          | 1  | 1        | Input  | No pull-up<br>No interrupt<br>PB4-PB7                              | Data in  |
|            |    |          | Input  | Analog input:<br>PA0-PA7<br>PB2-PB3                                | ADC      |
| 1          | 0  | x        | Output | Open drain: 20mA<br>PB4-PB7<br>Open drain: 5mA<br>PB2-PB3, PA5-PA7 | Data out |
| 1          | 1  | х        | Output | Push-pull                                                          | Data out |



#### **INPUT/OUTPUT PORTS** (Continued)

**SPI alternate function Option.** The I/O pins PB5-PB7 are also used by serial peripheral interface SPI. PB5 is connected with the SPI clock input SCL, PB6 is connected with the SPI data input SIN and PB7 is connected with the SPI data output SOUT.

For serial input operation PB5 and PB6 have to be programmed as inputs. For serial output operation PB7 has to be programmed as open-drain output (DDR = "1", OPR = "0"). In this operating mode the output of the SPI shift register instead of the port data register is connected to the port buffer. When PB7 is programmed as push-pull output (DDR = "1", OPR = "1"), the port data register is connected to the port buffer. When the SPI peripheral is not used PB5-PB7 can be used as general purpose I/O lines (provided that PB7 is not selected to be open-drain in output mode).

#### Notes:

Switching the I/O ports from one state to another should be done in a way that no unwanted side effects can happen. The recommended safe transitions are shown below. All other transitions are risky and should be avoided during change of operation mode as it is most likely that there will be an unwanted side-effect such as interrupt generation or two pins shorted together by the analog input lines.

Single bit SET and RES instructions should be used very carefully with Port A and B data registers because these instructions make an implicit read and write back of the whole addressed register byte. In port input mode however data register address reads from input pins, not from data register latches and data register information in input mode is used to set characteristics of the input pin (interrupt, pull-up, analog input), therefore these characteristics may be unintentionally reprogrammed depending on the state of input pins. As general rule is better to use SET and RES instructions on data register only when the whole port is in output mode. If input or mixed configuration is needed it is recommended to keep a copy of the data register in RAM. On this copy it is possible to use single bit instructions, then the copy register could be written into the port data register.

- SET bit, datacopy
- LD a, datacopy
- LD DRA, a

The WAIT and STOP instructions allow the ST62xx to be used in situations where low power consumption is needed. The lowest power consumption is achieved by configuring I/Os in input mode with well-defined logic levels.

The user has to take care not to switch outputs with heavy loads during the conversion of one of the analog inputs in order to avoid any disturbance in the measurement.

#### Figure 26. I/O Port State Transition Diagram for Safe



**Note** \*. xxx = DDR, OR, DR Bits respectively



#### TIMERS

The ST6242 offers an on-chip Timer peripheral consisting of an 8-bit counter with a 7-bit programmable prescaler. This Timer gives a maximum count of 2<sup>15</sup>, and contains a control logic that allows the configuration of the peripheral in three operating modes. Figure 27 shows the Timer block diagram. The content of the 8-bit counter can be read/written in the Timer/Counter register TCR which is addressed in the data space as a RAM location at addresses D3h. The state of the 7-bit prescaler can be read in the PSC register at address D2h. The control logic device is managed in the TSCR register (address D4h) as described in the following paragraphs.

The 8-bit counter is decrement by the output (rising edge) coming from the 7-bit prescaler and can be loaded and read under program control. When it decrements to zero then the TMZ (Timer Zero) bit in the TSCR is set to one. If the ETI (Enable Timer Interrupt) bit in the TSCR is also set to one an interrupt request, associated to interrupt vector #3, is generated. The Timer interrupt can be used to exit the MCU from the WAIT mode. The prescaler input is the oscillator frequency divided by 12. The prescaler input decrements on the rising edge. Depending on the division factor programmed by PS2, PS1 and PS0 bits in the TSCR, the clock input of the timer/counter register is multiplexed to different sources. On division factor 1, the clock input of the prescaler is also that of timer/counter; on factor 2, bit 0 of prescaler register is connected to the clock input of TCR. This bit changes its state with the half frequency of prescaler clock input. On factor 4, bit 1 of PSC is connected to clock input of TCR, and so on. On division factor 128, the MSB bit 6 of PSC is connected to the clock input of TCR. The prescaler initialize bit (PSI) in the TSCR register must be set to one to allow the prescaler (and hence the counter) to start. If it is cleared to zero then all of the prescaler bits are set to one and the counter is inhibited from counting. The prescaler can be given any value between 0 and 7Fh by writing to address D2h, if bit PSI in the TSCR register is set to one. The tap of the prescaler is selected using the PS2, PS1, PS0 bits in the control register. Figure 28 shows the Timer working principle.



Figure 27. Timer Peripheral Block Diagram



TIMERS (Continued)

#### **Timer Operating Modes**

The Timer has one operating mode. This mode is selected with TOUT= "1" in the Timer status control register TSCR (D4h).

The prescaler is decremented by the timer clock (OSC/12). The user can select the desired prescaler division ratio through the PS2, PS1, PS0 bits.

When the TCR count reach 0, it sets the TMZ bit in the TSCR.

#### **Timer Interrupt**

When the counter register decrements to zero and the software controlled ETI (Enable Timer Interrupt) bit is set to one then an interrupt request associated to interrupt vector #3 is generated. When the counter decrements to zero also the TMZ bit in the TSCR register is set to one.

#### Notes:

TMZ is set when the counter reaches 00h; however, it may be set by writing 00h in the TCR register or setting bit 7 of the TSCR register. TMZ bit must be cleared by user software when servicing the timer interrupt to avoid undesired interrupts when leaving the interrupt service routine. After reset, the 8-bit counter register is loaded to FFh while the 7-bit prescaler is loaded to 7Fh, and the TSCR register is cleared which means that timer is stopped (PSI="0") and the timer interrupt is disabled.

If the Timer is programmed in output mode, DOUT bit is transferred to the TIMER pin when TMZ is set

to one (by software or due to counter decrement). When TMZ is high, the latch is transparent and DOUT is copied to the timer pin. When TMZ goes low, DOUT is latched.

A write to the TCR register will predominate over the 8-bit counter decrement to 00h function, i.e. if a write and a TCR register decrement to 00h occur simultaneously, the write will take precedence, and the TMZ bit is not set until the 8-bit counter reaches 00h again. The values of the TCR and the PSC registers can be read accurately at any time.









#### TIMERS (Continued)

**TMZ.** Low-to-high transition indicates that the timer count register has decremented to zero. This bit must be cleared by user software before starting with a new count.

**ETI.** This bit, when set, enables the timer interrupt request (vector #3). If ETI="0" the timer interrupt is disabled. If ETI="1" and TMZ="1" an interrupt request is generated.

**TOUT.** This bit must be set high.

**DOUT.** Data sent to the timer output when TMZ is set high.

**PSI.** Used to initialize the prescaler and inhibit its counting. When PSI="0" the prescaler is set to 7Fh and the counter is inhibited. When PSI="1" the prescaler is enabled to count downwards. As long as PSI="0" both counter and prescaler are not running.

**PS2**, **PS1**, **PS0**. These bits select the division ratio of the prescaler register (see Table 8).

#### **Table 8. Prescaler Division Factors**

| PS2 | PS1 | PS0 | Divided by | PS2 | PS1 | PS0 | Divided by |
|-----|-----|-----|------------|-----|-----|-----|------------|
| 0   | 0   | 0   | 1          | 1   | 0   | 0   | 16         |
| 0   | 0   | 1   | 2          | 1   | 0   | 1   | 32         |
| 0   | 1   | 0   | 4          | 1   | 1   | 0   | 64         |
| 0   | 1   | 1   | 8          | 1   | 1   | 1   | 128        |

#### Figure 30. Timer Counter Register



#### Figure 31. Prescaler Register





#### DIGITAL WATCHDOG

The ST6242 watchdog is a software activated watchdog.

Figure 32 shows the watchdog block diagram while Figure 34 shows its working principle.

The software activated digital watchdog consists of a down counter that can be used to provide a controlled recovery from a software upset or as a simple 7-bit timer for general purpose counting. The watchdog uses one data space register (DWDR location D8h). The watchdog register is set to FEh after reset and the watchdog function is disabled. The watchdog time can be programmed using the 6 Most Significant Bits in the Watchdog register. The check time can be set differently for different routines within the general program.

After a reset the software Watchdog is in the offstate. The watchdog should be activated inside the Reset restart routine by writing a "1" in watchdog timer register bit 0. Bit one of this register must be set to one before programming bit zero as otherwise a reset will be immediately generated when bit 0 is set. This allows the user to generate a reset by software (bit 0 = "1", bit 1 = "0"). Once bit 0 is set, it can not be cleared by software without generating a Reset. The delay time is defined by programming bits 2-7 of the watchdog register. Bit 7 is the Least Significant Bit while bit 2 is the MSB. This gives the possibility to generate a reset in a time between 3072 to 196608 clock cycles in 64 possible steps: (With a clock frequency of 8MHz this means from 384µs to 24.576ms). The reset is prevented if the register is reloaded with the desired value before bits 2-7 decrement from all zeros to all ones. If the watchdog is active the STOP instruction is deactivated and a WAIT instruction is automatically executed instead of a STOP. If bit 0 of the watchdog register is never set to one then bits 1-7 of the register can be used as a simple 7-bit counter which is decrement every 3072 clock cycles.





Figure 32. Digital Watchdog Block Diagram





#### **DIGITAL WATCHDOG** (Continued)

#### Watchdog Register

**C.** This is the watchdog activation bit, that, if set to one, will activate the watchdog function. When cleared to zero it allows the use of the counter as a 7-bit timer. This bit is cleared on reset.

**SR.** This bit is set to one during the reset and will generate a software reset if cleared to zero. When C = "0" (watchdog disabled software option) it is the MSB of the 7-bit timer.

**T1-T6.** These are the watchdog counter bits. It should be noted that D7 (T1) is the LSB of the counter and D2 (T6) is the MSB of the counter. These bits are in the opposite order to normal.

#### Application note:

If the Watchdog is not used during power-on reset external noise may cause the undesired activation of the Watchdog with a generation of an unexpected reset. To avoid this risk, two additional instructions, that check the state of the watchdog and eventually reset the chip are needed within the first 27 instructions, after the reset. These instructions are:

jrx 0, WD, #+3 ldi WD, 0FDH

These instructions should be executed at the very beginning of the customer program.

If the Watchdog is used, during power-on reset the Watchdog register may be set to a low value, that could give a reset after 28 instructions earliest. To avoid undesired resets, the Watchdog must be set to the desired value within the first 27 instructions, the best is to put at the very beginning.

Alternatively the normal legal state can be checked with the following short routine:

ldi a, OFEH and a, WD cpi a, OFEH jrz #+3 ldi WD, OFDH

This sequence is recommended for security applications, where possible stack confusion error loops must be avoided and the Watchdog must only be refreshed after extensive checks.



#### Figure 34. Watchdog Working Principle



### ST6242

#### 8-BIT A/D C ONVERTER

The A/D converter of ST6242 is an 8-bit analog to digital converter with 6 analog inputs (as alternate functions of I/O lines PA4-PA7, PB2-PB3) offering 8-bit resolution with total accuracy  $\pm 2$  LSB and a typical conversion time of 70µs (clock frequency of 8MHz).

The A/D peripheral converts the input voltage by a process of successive approximations using a clock frequency derived from the oscillator with a division factor of twelve. With an oscillator clock frequency less than 1.2MHz, the A/D converter accuracy is decreased.

The selection of the pin signal that has to be converted is done by configuring the related I/O line as analog input through the I/O ports option and data registers (refer to I/O ports description for additional information). Only one I/O line must be configured as analog input at a time. The user must avoid the situation in which more than one I/O pin is selected to be analog input to avoid malfunction of the ST62xx.

The ADC uses two registers in the data space: the ADC data conversion register which stores the conversion result and the ADC control register used to program the ADC functions.

A conversion is started by writing a "1" to the Start bit (STA) in the ADC control register. This automatically clears (resets to "0") the End Of Conversion Bit (EOC). When a conversion has been finished this EOC bit is automatically set to "1" in order to flag that conversion is complete and that the data in the ADC data conversion register is valid. Each conversion has to be separately initiated by writing to the STA bit.

The STA bit is continually being scanned so that if the user sets it to "1" while a previous conversion is in progress then a new conversion is started before the previous one has been completed. The start bit (STA) is a write only bit, any attempt to read it will show a logical "0".

The A/D converter has a maskable interrupt associated to the end of conversion. This interrupt is associated to the interrupt vector #4 and occurs when the EOC bit is set, i.e. when a conversion is completed. The interrupt is masked using the EAI (interrupt mask) bit in the control register.

The power consumption of the device can be reduced by turning off the ADC peripheral. That is achieved when the PDS bit in the ADC control register is cleared to "0". If PDS="1", the A/D is supplied and enabled for conversion. This bit must be set at least one instruction before the beginning of the conversion to allow the stabilization of the



Figure 35. A/D Converter Block Diagram

Figure 36. A/D Converter Control Register



Figure 37. A/D Converter Data Register



A/D converter. This action is needed also before entering the STOP instruction as the A/D comparator is not automatically disabled by the STOP mode

During reset any conversion in progress is stopped, the control register is reset to all zeros and the A/D interrupt is masked (EAI=0).



#### 8-BIT A/D CONVERTER(Continued)

#### A/D Converter Control Register

**EAI.** If this bit is set to one the A/D interrupt (vector #4) is enabled, when EAI=0 the interrupt is disabled.

**EOC.** Read Only; This read only bit indicates when a conversion has been completed. This bit is automatically reset to zero when the STA bit is written. If the user is using the interrupt option then this bit can be used as an interrupt pending bit. Data in the data conversion register are valid only when this bit is set to one.

**STA.** *Write Only*, Writing a "1" in this bit will start a conversion on the selected channel and automatically reset to zero the EOC bit. If the bit is set again when a conversion is in progress, the present conversion is stopped and a new one will take place. This bit is write only, any attempt to read it will show a logical zero.

**PDS.** This bit activates the A/D converter if set to 1. Writing a zero into this bit will put the ADC in power down mode (idle mode).

#### D3-D0. Not used

#### A/D Converter Data Register

**D7-D0.** Read Only, These are the conversion result bits; the register is read only and stores the result of the last conversion. The contents of this register are valid only when EOC bit in the ADCR register is set to one (end-of-conversion).

#### Notes:

The ST62xx A/D converter does not feature a sample and hold. The analog voltage to be measured should therefore be stable during the conversion time. Variation should not exceed  $\pm 1/2$  LSB for the best accuracy in measurement.

Since the ADC is on the same chip as the microprocessor the user should not switch heavily loaded output signals during conversion if high precision is needed. This is because such switching will affect the supply voltages which are used for comparisons.

A low pass filter can be used at the analog input pins to reduce input voltage variation during the conversion. For true 8 bit conversions the impedance of the analog voltage sources should be less than  $30k\Omega$  while the impedance of the reference voltage should not exceed  $2k\Omega$ .

The accuracy of the conversion depends on the quality of the power supply voltages ( $V_{DD}$  and  $V_{SS}$ ). The user must specially take care of applying regulated reference voltage on the  $V_{DD}$  and  $V_{SS}$  pins

(the variation of the power supply voltage must be inferior to 5V/ms).

The converter can resolve the input voltage with an resolution of:

$$\frac{V_{DD}-V_{SS}}{256}$$

So if operating with a supply voltage of 5V the resolution is about 20mV.

The Input voltage (Ain) which has to be converted must be constant for  $1\mu s$  before conversion and remain constant during the conversion.

The resolution of the conversion can be improved if the power supply voltage ( $V_{DD}$ ) of the microcontroller becomes lower.

In order to optimize the resolution of the conversion, the user can configure the microcontroller in the WAIT mode because this mode allows the minimization of the noise disturbances and the variations of the power supply voltages due to the switching of the outputs. Nevertheless, it must be take care of executing the WAIT instruction as soon as possible after the beginning of the conversion because the execution of the WAIT instruction may provide a small variation of the V<sub>DD</sub> voltage (the negative effect of this variation is minimized at the beginning of the conversion because the latter is less sensitive than the end of the conversion when the less significant bits are determined).

The best configuration from a accuracy point of view is the WAIT mode with the Timer and LCD driver stopped. Indeed, only the ADC peripheral and the oscillator are still working. The MCU has to be wake-up from the WAIT mode by the interrupt of the ADC peripheral at the end of the conversion. It must be noticed that the wake-up of the microcontroller could be done also with the interrupt of the TIMER, but in this case, the Timer is working and some noise could disturb the converter in terms of accuracy.



#### **SERIAL PERIPHERAL INTERFACE (SPI)**

The ST6242 SPI is an optimized serial synchronous interface that supports a wide range of industry standard SPI specifications. The ST6242 SPI is controlled by small and simple user software to perform serial data exchange. The serial shift clock can be implemented either by software (using the bit-set and bit-reset instructions), with the on-chip Timer 1 by externally connecting the SPI clock pin to the timer pin or by directly applying an external clock to the SPI.

The peripheral is composed by an 8-bit Data/shift Register (address DDh) and a 4-bit binary counter. The SCL, Sin and Sout SPI data and clock signals are connected to the PB5, PB6 and PB7 I/O lines. With the 3 I/O pins, the SPI can operate in the following operating modes: Software SPI, S-BUS, I<sup>2</sup>C-bus and as a standard serial I/O (clock, data, enable). An interrupt request can be generated after eight clock pulses. Figure 39 shows the SPI block diagram.

The PB5/SCL line clocks, on the falling edge, the shift register and the counter. To allow SPI operation the PB5/SCL must be programmed as input, an external clock supplied to this pin will drive the SPI peripheral (slave mode).

If PB5/SCL is programmed as output, a clock signal can be generated by software, setting and resetting the port line by software (master mode).

#### Figure 38. SPI Data/Shift Register



The SCL clock signal is the shift clock for the SPI data/shift register. The PB6/Sin pin is the serial shift input and PB7/Sout is the serial shift output. These two lines can be tied together to implement two wires protocols (I<sup>2</sup>C-bus, etc). When data is serialized, the MSB is the first bit. PB6/Sin has to be programmed as input. For serial output operation PB7/Sout has to be programmed as open-drain output.

After 8 clock pulses (D7..D0) the output  $\overline{Q4}$  of the 4-bit binary counter becomes low, disabling the clock from the counter and the data/shift register. Q4 enables the clock to generate an interrupt on the 8th clock falling edge as long as no reset of the counter (processor write into the 8-bit data/shift register) takes place. After a processor reset the interrupt is disabled. The interrupt is active when writing data in the shift register (DDh) and desactivated when writing any data in the register SPI Interrupt Disable (C2h).

The generation of an interrupt to the Core provides information that new data is available (input mode) or that transmission is completed (output mode), allowing the Core to generate an acknowledge on the 9th clock pulse (I<sup>2</sup>C-bus).

Since the SPI interrupt is connected to interrupt #1, the falling edge interrupt option should be selected by clearing to zero bit 6 of the Interrupt Option Register (IOR, C8h).

After power on reset, or after writing the data/shift register, the counter is reset to zero and the clock is enabled. In this condition the data shift register is ready for reception. No start condition has to be detected. Through the user software the Core may pull down the Sin line (Acknowledge) and slow down the SCL, as long as it is needed to carry out data from the shift register.



#### SERIAL PERIPHERAL INTERFACE (Continued)

#### I<sup>2</sup>C-bus Master-Slave, Receiver-Transmitter

When pins Sin and Sout are externally connected togetherit is possible to use the SPI as a receiver as well as a transmitter. With a simple software routine (by using bit-set and bit-reset on I/O line) a clock can be generated allowing I<sup>2</sup>C-bus to work in master mode.

When implementing an  $l^2$ C-bus protocol, the start condition can be detected by setting the processor into a "wait for start" condition by simply enabling the interrupt of the PA6/Sin I/O port. This frees the processor from polling the Sin and SCL lines. After the transmission/reception the processor has to poll for the STOP condition.

In slave mode the user software can slow down the SCL clock frequency by simply putting the SCL I/O line in output open-drain mode and writing a zero into the corresponding data register bit.

As it is possible to directly read the Sin pin directly through the port register, the software can detect a difference between internal data and external data (master mode). Similar condition can be applied to the clock.

The typical speed of transmission in  $I^2C$  master or slave mode is in the range of 10kHz.

#### Three (Four) Wire Serial Bus

It is possible to use a single general purpose I/O pin (with the corresponding interrupt enabled) as a "chip enable" pin. SCL acts as active or passive clock pin, Sin as data in and Sout as data out (four wire bus). Sin and Sout can be connected together externally to implement three wire bus.

#### Note:

When the SPI is not used, the three I/O lines (Sin, SCL, Sout) can be used as normal I/O, with the following limitation: bit Sout cannot be used in open drain mode as this enables the shift register output to the port.

It is recommended, in order to avoid spurious interrupts from the SPI, to disable the SPI interrupt (the default state after reset) i.e. no write must be made to the 8-bit shift register (DDh). An explicit interrupt disable may be made in software by a dummy write to address C2h.



#### Figure 39. SPI Block Diagram



#### LCD CONTROLLER-DRIVER

The ST6242 LCD driver consists of a LCD control logic, a programmable prescaler, a 24 bytes wide dedicated LCD RAM, 40 segment and 4 common outputs. This allows a direct driving of up to 160 LCD segments.

The LCD driver is managed by the LCD Mode/Control register located at data RAM address DCh. Different display modes (1/1 duty, 1/2 duty, 1/3 duty and 1/4 duty) are available to cover a wide range of application requirements. The multiplexing display modes are software selectable by programming bits 6 and 7 of the LCD control register. Bits 0-5 are used to select the LCD drive and frame frequency (in relation to the system clock) and to switch off all segments.

According to the data in the LCD RAM, the segment and the common drivers generate the segment and common signals which can directly drive an LCD panel.

The LCD control logic reads automatically the data from the LCD RAM independently and without interruption of the processor. The part of the LCD RAM that is not used for displaying can be used as normal data memory.

The scale factor of the clock prescaler can be fixed by software, therefore different frame frequencies can be defined.

The ST6242 oscillator should operate with a 1.0486, 2.0972, 4.1943, 8.3886MHz frequency quartz crystal. This allows the associated division rates to achieve an internal reference frequency of 32.768kHz. The different division rates can be achieved by programming bits 3, 4, 5 in the LCD control register (see Table 10). It is not recommended to select an internal frequency lower than 32.768kHz as the clock supervisor circuit may switch off the LCD peripheral if the lower frequency is detected.

When the display is turned off, all segment and common outputs are switched to ground, causing all the segments to be switched off regardless of the contents of the LCD RAM.

To avoid incomplete frames of the LCD, the mode control bits do not immediately influence the LCD controller when the LCD control register is written. They are stored in a temporary register and change the LCD function only at the end of the frame. Different LCD frame frequencies for each display mode are selected by bits in the LCD control register (see Table 11).



**DS0, DS1.** Duty cycle select bits. These bits select the number of common backplanes used by the LCD control. This allows different multiplexing conditions.

**HF0, HF1, HF2.** These bits allow the LCD controller to be supplied with the correct frequency when different high main oscillator frequencies are selected as system clock. Table 10 shows the set-up for different clock crystals.

**LF0, LF1, LF2.** These bits control the LCD base operational frequency of the LCD common lines. Table 11 shows the set-up to select the different frequencies while Table 12 shows the corresponding frame values with the different multiplexing conditions.

#### **Table 9. Duty Cycle Selection**

SGS-THOMSON MICROELECTRONICS

| DS1 | DS0 | Display<br>Mode | Active<br>Blackplanes | Max.<br>Number of<br>Segments<br>Driven |
|-----|-----|-----------------|-----------------------|-----------------------------------------|
| 0   | 0   | 1/4 duty        | COM1, 2, 3, 4         | 180                                     |
| 0   | 1   | 1/1 duty        | COM1                  | 45                                      |
| 1   | 0   | 1/2 duty        | COM1, 2               | 90                                      |
| 1   | 1   | 1/3 duty        | COM1, 2, 3            | 135                                     |

#### Table 10. High Frequency Select Bits

| HF2 | HF1 | HF0 | Function                  | fosc      |
|-----|-----|-----|---------------------------|-----------|
| 0   | 0   | 0   | Display off               |           |
| 0   | 0   | 1   | for stand-by Oscillator   | 32.768kHz |
| 0   | 1   | 0   | NOT TO BE USED            |           |
| 0   | 1   | 1   | ÷ 32 for main oscillator  | 1.048MHz  |
| 1   | 0   | 0   | ÷ 64 for main oscillator  | 2.097MHz  |
| 1   | 0   | 1   | ÷ 128 for main oscillator | 4.194MHz  |
| 1   | 1   | 0   | ÷ 256 for main oscillator | 8.388MHz  |
| 1   | 1   | 1   | NOT TO BE USED            |           |

Notes :

The usage f<sub>osc</sub> values different from those defined in this table cause the LCD to operate at a reference frequency different from 32.768kHz.
 It is not recommended to select an internal frequency lower than 32.768kHz as the clock supervisor circuit may switch off the LCD peripheral if lower frequency is detected.

| LF2 | LF1 | LF0 | f <sub>LCD</sub> (Hz) |
|-----|-----|-----|-----------------------|
| 0   | 0   | 0   | 64                    |
| 0   | 0   | 1   | 85                    |
| 0   | 1   | 0   | 128                   |
| 0   | 1   | 1   | 171                   |
| 1   | 0   | 0   | 256                   |
| 1   | 0   | 1   | 341                   |
| 1   | 1   | 0   | 512                   |
| 1   | 1   | 1   | Not to be Used        |

#### Table 11. LCD Frequency Select Bits

According to the selected LCD drive frequency  $f_{LCD}$  the frame frequencies come out as shown in Table 12.

The Figure 47 illustrates the waveforms of the different duty signals.

The value of the VLCD voltage can be chosen independently from  $V_{DD}$  according to the display require-

#### Table 12. Available Frame Frequencies for LCD

| f <sub>LCD</sub> | Frame Frequency f <sub>F</sub> (Hz) |     |          |     |  |  |  |  |
|------------------|-------------------------------------|-----|----------|-----|--|--|--|--|
| (Hz)             | 1/1 duty 1/2 duty 1/3 duty          |     | 1/4 duty |     |  |  |  |  |
| 512              | 512                                 | 256 | 171      | 128 |  |  |  |  |
| 341              | 341                                 | 171 | 114      | 85  |  |  |  |  |
| 256              | 256                                 | 128 | 85       | 64  |  |  |  |  |
| 171              | 171                                 | 85  | 57       | 43  |  |  |  |  |
| 128              | 128                                 | 64  | 43       | 32  |  |  |  |  |
| 85               | 85                                  | 43  | 28       | 21  |  |  |  |  |
| 64               | 64                                  | 32  | 21       | 16  |  |  |  |  |

ments. The intermediate VLCD levels 2/3 VLCD, 1/3 VLCD and 1/2 VLCD are generated by an internal resistor network as shown in Figures 45 and 46. The half VLCD level for 1/2 duty cycle is obtained by the external connection of VLCD1/3 and VLCD2/3 pins. All intermediate VLCD levels are connected to pins to enable external capacitive buffering or resistive shunting.



The internal resistive divider network is realized with two parallel dividers. One has high resistivity, the other one low resistivity. The high resistive divider ( $R_H$ ) is permanently switched on during the LCD operation. The low resistive divider ( $R_L$ ) is only switched on for a short period of time when the levels of common lines and segment lines are changed. This method combines low source impedance for fast switching of the LCD pixels with high source impedance for low power consumption. Figure 41 shows the typical current into V<sub>LCD</sub> pin in dependency of the display voltage V<sub>LCD</sub>.

When the display is switched off (by program or reset) the internal resistor network is also switched off to achieve minimum power consumption. The low resistivity divider is active at each edge of  $f_{LCD}$  during 8 clock cycles of  $F_{32kHz}$ .

The internal resistor network is implemented with resistive transistor elements to achieve high precision. For display voltages  $V_{LCD} < 4.5V$  the resistivity of the divider may be too high for some applications (especially using 1/3 or 1/4 duty display mode). In that case an external resistive divider must be used to achieve the desired resistivity.

## Figure 41. Typical Current Consumption on VLCD Pin (25°C, no load, fLCD=512 Hz, mux=1/3-1/4)



Figure 42. Typical Chronogram of Activation of the  $V_{LCD}$  Divider Network



Typical External resistances values are in the range of 100 k $\Omega$  to 150 k $\Omega$ . External capacitances in the range of 10 to 47 nF can be added to V<sub>LCD</sub> 2/3 and V<sub>LCD</sub> 1/3 pins and to V<sub>LCD</sub> if the V<sub>LCD</sub> connection is highly impedant.

When the program is switched off (by program or reset) the internal resistor network is also switched off to achieve minimum power consumption.





#### Figure 44. Generation of the 32kHz clock





#### Figure 45. Bias Configuration for 1/2 Duty

## Figure 46. Bias Configuration for 1/1, 1/3 and 1/4 Duty Operation of LCD





#### Address Mapping of the Display Segments.

The LCD RAM is located in the ST6242 data space from addresses E0h to F7h. The LCD forms a matrix of 40 segment lines (rows) and up to 4 common lines (columns). Each bit of the LCD RAM is mapped to one element of the LCD matrix, as described in Figure 48. If a bit is set, the corresponding LCD segment is switched on; if it is reset, the segment is switched off. The segments outputs S1to S8 are not connected to any pin.

When multiplex rates lower than 1/4 are selected, the unused LCD RAM is free for general use. In the 1/2 duty mode, for instance, half of the LCD RAM is available for storing general purpose data. The address range from F8h to FEh can be used as general purpose data RAM, but not for displaying data (it is reserved for future LCD expansion).

After a reset, the LCD RAM is not initializated and contains arbitrary information. As the LCD control register is reset, the LCD is completely switched off.



#### Figure 47. Common Signal Waveforms



#### Figure 48. Addressing Map of the LCD RAM

| Data RAM<br>Address                | MSB                                  |                                 |                                 |                                 |                                 |                                 |                                 | LSB                            |      |
|------------------------------------|--------------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|--------------------------------|------|
| E0 *<br>E1<br>E2<br>E3<br>E4<br>E5 | S16<br>S24<br>S32<br>S40<br>S48      | S15<br>S23<br>S31<br>S39<br>S47 | S14<br>S22<br>S30<br>S38<br>S46 | S13<br>S21<br>S29<br>S37<br>S45 | S12<br>S20<br>S28<br>S36<br>S44 | S11<br>S19<br>S27<br>S35<br>S43 | S10<br>S18<br>S26<br>S34<br>S42 | S9<br>S17<br>S25<br>S33<br>S41 | COM1 |
| E6 *<br>E7<br>E8<br>E9<br>EA<br>EB | S16<br>S24<br>S32<br>S40<br>S48      | S15<br>S23<br>S31<br>S39<br>S47 | S14<br>S22<br>S30<br>S38<br>S46 | S13<br>S21<br>S29<br>S37<br>S45 | S12<br>S20<br>S28<br>S36<br>S44 | S11<br>S19<br>S27<br>S35<br>S43 | S10<br>S18<br>S26<br>S34<br>S42 | S9<br>S17<br>S25<br>S33<br>S41 | COM2 |
| EC *<br>ED<br>EE<br>EF<br>F0<br>F1 | S16<br>S24<br>S32<br>S40<br>S48      | S15<br>S23<br>S31<br>S39<br>S47 | S14<br>S22<br>S30<br>S38<br>S46 | S13<br>S21<br>S29<br>S37<br>S45 | S12<br>S20<br>S28<br>S36<br>S44 | S11<br>S19<br>S27<br>S35<br>S43 | S10<br>S18<br>S26<br>S34<br>S42 | S9<br>S17<br>S25<br>S33<br>S41 | СОМЗ |
| F2 *<br>F3<br>F4<br>F5<br>F6<br>F7 | \$16<br>\$24<br>\$32<br>\$40<br>\$48 | S15<br>S23<br>S31<br>S39<br>S47 | S14<br>S22<br>S30<br>S38<br>S46 | S13<br>S21<br>S29<br>S37<br>S45 | S12<br>S20<br>S28<br>S36<br>S44 | S11<br>S19<br>S27<br>S35<br>S43 | S10<br>S18<br>S26<br>S34<br>S42 | S9<br>S17<br>S25<br>S33<br>S41 | COM4 |
| F8 - FE *                          |                                      |                                 |                                 |                                 |                                 |                                 |                                 |                                |      |

**Note** \*. Row to be used as general purpose RAM (not for display data)

#### Notes:

In STOP mode no clock is available for the LCD controller from the main oscillator. If the 32kHz oscillator is activated the LCD can also operate in STOP mode. If the stand-by oscillator is not active, the LCD controller is switched off when STOP instruction is executed; this mode has to be selected to reach the lowest power consumption.

A missing LCD clock (no oscillator active, broken crystal, etc.) is detected by a clock supervisor circuit that switches all the segments and common lines to ground to avoid destructive DC levels at the LCD.

The LCD function change is only effective at the end of a frame. For this reason special care has to be taken when entering the STOP mode. After switching the LCD clock source from the main oscillator to the 32kHz stand-by oscillator it must be guaranteed that enough clock pulses are delivered to complete the current frame before entering the STOP mode. Otherwise the LCD function will not be changed and the LCD is switched off after entering the STOP mode.

The RAM addresses E6-EC-F2-F8/FE are not used for LCD display purposes. So they are available as 10 additional Data RAM registers.



#### SOFTWARE DESCRIPTION

The ST62xx software has been designed to fully use the hardware in the most efficient way possible while keeping byte usage to a minimum, in short to provide byte efficient programming capability. The ST62xx core has the ability to set or clear any register or RAM location bit of the Data space with a single instruction. Furthermore, the program may branch to a selected address depending on the status of any bit of the Data space. The carry bit is stored with the value of the bit when the SET or RES instruction is processed.

#### Addressing Modes

The ST62xx core has nine addressing modes which are described in the following paragraphs. The ST62xx core uses three different address spaces: Program space, Data space, and Stack space. Program space contains the instructions which are to be executed, plus the data for immediate mode instructions. Data space contains the Accumulator, the X,Y,V and W registers, peripheral and Input/Output registers, the RAM locations and Data ROM locations (for storage of tables and constants). Stack space contains six 12-bit RAM cells used to stack the return addresses for subroutines and interrupts.

**Immediate.** In the immediate addressing mode, the operand of the instruction follows the opcode location. As the operand is a ROM byte, the immediate addressing mode is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter).

**Direct.** In the direct addressing mode, the address of the byte that is processed by the instruction is stored in the location that follows the opcode. Direct addressing allows the user to directly address the 256 bytes in Data Space memory with a single two-byte instruction.

**Short Direct.** The core can address the four RAM registers X,Y,V,W (locations 80h, 81h, 82h, 83h) in the short-direct addressing mode . In this case, the instruction is only one byte and the selection of the location to be processed is contained in the op-code. Short direct addressing is a subset of the direct addressing mode. (Note that 80h and 81h are also indirect registers).

**Extended.** In the extended addressing mode, the 12-bit address needed to define the instruction is obtained by concatenating the four less significant bits of the opcode with the byte following the opcode. The instructions (JP, CALL) that use the extended addressing mode are able to branch to any address of the 4K bytes Program space.

An extended addressing mode instruction is twobyte long. Program Counter Relative. The relative addressing mode is only used in conditional branch instructions. The instruction is used to perform a test and, if the condition is true, a branch with a span of -15 to +16 locations around the address of the relative instruction. If the condition is not true, the instruction that follows the relative instruction is executed. The relative addressing mode instruction is onebyte long. The opcode is obtained in adding the three most significant bits that characterize the kind of the test, one bit that determines whether the branch is a forward (when it is 0) or backward (when it is 1) branch and the four less significant bits that give the span of the branch (0h to Fh) that must be added or subtracted to the address of the relative instruction to obtain the address of the branch.

**Bit Direct.** In the bit direct addressing mode, the bit to be set or cleared is part of the opcode, and the byte following the opcode points to the address of the byte in which the specified bit must be set or cleared. Thus, any bit in the 256 locations of Data space memory can be set or cleared.

**Bit Test & Branch.** The bit test and branch addressing mode is a combination of direct addressing and relative addressing. The bit test and branch instruction is three-byte long. The bit identification and the tested condition are included in the opcode byte. The address of the byte to be tested follows immediately the opcode in the Program space. The third byte is the jump displacement, which is in the range of -126 to +129. This displacement can be determined using a label, which is converted by the assembler.

**Indirect.** In the indirect addressing mode, the byte processed by the register-indirect instruction is at the address pointed by the content of one of the indirect registers, X or Y (80h,81h). The indirect register is selected by the bit 4 of the opcode. A register indirect instruction is one byte long.

**Inherent.** In the inherent addressing mode, all the information necessary to execute the instruction is contained in the opcode. These instructions are one byte long.



#### Instruction Set

The ST62xx core has a set of 40 basic instructions. When these instructions are combined with nine addressing modes, 244 usable opcodes can be obtained. They can be divided into six different types:load/store, arithmetic/logic, conditional branch, control instructions, jump/call, bit manipulation. The following paragraphs describe the different types.

All the instructions within a given type are presented in individual tables. **Load & Store.** These instructions use one,two or three bytes in relation with the addressing mode. One operand is the Accumulator for LOAD and the other operand is obtained from data memory using one of the addressing modes.

For Load Immediate one operand can be any of the 256 data space bytes while the other is always immediate data.

| Instruction |                 | Dutes | Civalaa | Fla | ags |
|-------------|-----------------|-------|---------|-----|-----|
| Instruction | Addressing Mode | Bytes | Cycles  | Z   | С   |
|             |                 |       |         |     |     |
| LD A, X     | Short Direct    | 1     | 4       | Δ   | *   |
| LD A, Y     | Short Direct    | 1     | 4       | Δ   | *   |
| LD A, V     | Short Direct    | 1     | 4       | Δ   | *   |
| LD A, W     | Short Direct    | 1     | 4       | Δ   | *   |
| LD X, A     | Short Direct    | 1     | 4       | Δ   | *   |
| LD Y, A     | Short Direct    | 1     | 4       | Δ   | *   |
| LD V, A     | Short Direct    | 1     | 4       | Δ   | *   |
| LD W, A     | Short Direct    | 1     | 4       | Δ   | *   |
| LD A, rr    | Direct          | 2     | 4       | Δ   | *   |
| LD rr, A    | Direct          | 2     | 4       | Δ   | *   |
| LD A, (X)   | Indirect        | 1     | 4       | Δ   | *   |
| LD A, (Y)   | Indirect        | 1     | 4       | Δ   | *   |
| LD (X), A   | Indirect        | 1     | 4       | Δ   | *   |
| LD (Y), A   | Indirect        | 1     | 4       | Δ   | *   |
|             |                 |       |         |     |     |
|             |                 |       |         |     |     |
| LDI A, #N   | Immediate       | 2     | 4       | Δ   | *   |
| LDI rr, #N  | Immediate       | 3     | 4       | *   | *   |
|             |                 |       |         |     |     |

#### Table 13. Load & Store Instructions

Notes:

X,Y. Indirect Register Pointers, V & W Short Direct Registers

# . Immediate data (stored in ROM memory)

rr. Data space register

 $\Delta$  . Affected

\*. Not Affected



Arithmetic and Logic. These instructions are used to perform the arithmetic calculations and logic operations. In AND, ADD, CP, SUB instructions one operand is always the accumulator while the other can be either a data space memory content or an immediate value in relation with the addressing mode. In CLR, DEC, INC instructions the operand can be any of the 256 data space addresses. In COM, RLC, SLA the operand is always the accumulator.

| Instruction                                                               | Addressing Mede                                                                          | Button                          | Cycles                                    | Fla                                                                                                                               | Flags                                        |  |  |
|---------------------------------------------------------------------------|------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--|--|
| Instruction                                                               | Addressing Mode                                                                          | Bytes                           | Cycles                                    | Z                                                                                                                                 | С                                            |  |  |
| ADD A, (X)<br>ADD A, (Y)<br>ADD A, rr                                     | Indirect<br>Indirect<br>Direct                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $\Delta \\ \Delta \\ \Delta$                                                                                                      | $\Delta$<br>$\Delta$<br>$\Delta$             |  |  |
| ADDI A, #N                                                                | Immediate                                                                                | 2                               | 4                                         | Δ                                                                                                                                 | Δ                                            |  |  |
| AND A, (X)<br>AND A, (Y)<br>AND A, rr                                     | Indirect<br>Indirect<br>Direct                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $\Delta$<br>$\Delta$<br>$\Delta$                                                                                                  | * * *                                        |  |  |
| ANDI A, #N                                                                | Immediate                                                                                | 2                               | 4                                         | Δ                                                                                                                                 | *                                            |  |  |
| CLR A<br>CLR rr                                                           | Short Direct<br>Direct                                                                   | 2<br>3                          | 4<br>4                                    | Δ<br>*                                                                                                                            | Δ<br>*                                       |  |  |
| COM A                                                                     | Inherent                                                                                 | 1                               | 4                                         | Δ                                                                                                                                 | Δ                                            |  |  |
| CP A, (X)<br>CP A, (Y)<br>CP A, rr                                        | Indirect<br>Indirect<br>Direct                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $\Delta$<br>$\Delta$<br>$\Delta$                                                                                                  | $\Delta$<br>$\Delta$<br>$\Delta$             |  |  |
| CPI A, #N                                                                 | Immediate                                                                                | 2                               | 4                                         | Δ                                                                                                                                 | Δ                                            |  |  |
| DEC X<br>DEC Y<br>DEC V<br>DEC W<br>DEC A<br>DEC rr<br>DEC (X)<br>DEC (Y) | Short Direct<br>Short Direct<br>Short Direct<br>Direct<br>Direct<br>Indirect<br>Indirect | 1<br>1<br>1<br>2<br>2<br>1<br>1 | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 | Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ                                                                                              | * * * * * *                                  |  |  |
| INC X<br>INC Y<br>INC V<br>INC W<br>INC A<br>INC rr<br>INC (X)<br>INC (Y) | Short Direct<br>Short Direct<br>Short Direct<br>Direct<br>Direct<br>Indirect<br>Indirect | 1<br>1<br>1<br>2<br>2<br>1<br>1 | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 | $ \begin{array}{c} \Delta \\ \Delta \end{array} $ | * * * * * *                                  |  |  |
| RLC A                                                                     | Inherent                                                                                 | 1                               | 4                                         | Δ                                                                                                                                 | Δ                                            |  |  |
| SLA A<br>SUB A, (X)<br>SUB A, (Y)<br>SUB A, rr                            | Inherent<br>Indirect<br>Indirect<br>Direct                                               | 2<br>1<br>1<br>2                | 4<br>4<br>4<br>4                          | $\Delta$<br>$\Delta$<br>$\Delta$<br>$\Delta$                                                                                      | $\Delta$<br>$\Delta$<br>$\Delta$<br>$\Delta$ |  |  |
| SUBI A, #N                                                                | Immediate                                                                                | 2                               | 4                                         | Δ                                                                                                                                 | Δ                                            |  |  |
|                                                                           |                                                                                          | 1                               | 1                                         |                                                                                                                                   | ·                                            |  |  |

#### Table 14. Arithmetic & Logic Instructions

Notes:

# Immediate data (stored in ROM memory)

rr. Data space register

 $\Delta$ . Affected

\* . Not Affected



X,Y.Indirect Register Pointers, V & W Short Direct Registers

Conditional Branch. The branch instructions achieve a branch in the program when the selected condition is met.

Bit Manipulation Instructions. These instructions can handle any bit in data space memory. One group either sets or clears. The other group (see Conditional Branch) performs the bit test branch operations.

Control Instructions. The control instructions control the MCU operations during program execution.

Jump and Call. These two instructions are used to perform long (12-bit) jumps or subroutines call inside the whole program space.

#### Table 15. Conditional Branch Instructions

| Instruction   | Branch If | Bytes | Civalaa | Flags |   |
|---------------|-----------|-------|---------|-------|---|
| instruction   | Branch II | Bytes | Cycles  | Z     | С |
| JRC e         | C = 1     | 1     | 2       | *     | * |
| JRNC e        | C = 0     | 1     | 2       | *     | * |
| JRZ e         | Z = 1     | 1     | 2       | *     | * |
| JRNZ e        | Z = 0     | 1     | 2       | *     | * |
| JRR b, rr, ee | Bit = 0   | 3     | 5       | *     | Δ |
| JRS b, rr, ee | Bit = 1   | 3     | 5       | *     | Δ |

Notes:

b. 3-bit address

5 bit signed displacement in the range -15 to +16 e.

ee. 8 bit signed displacement in the range -126 to +129

#### **Table 16. Bit Manipulation Instructions**

| Instruction          | Addressing Mede          | Button | Cycles | Fla | igs |
|----------------------|--------------------------|--------|--------|-----|-----|
| Instruction          | Addressing Mode          | Bytes  | Cycles | Z   | c   |
| SET b,rr<br>RES b,rr | Bit Direct<br>Bit Direct | 2<br>2 | 4<br>4 | *   | *   |

Notes:

b. 3-bit address;

rr. Data space register;

#### **Table 17. Control Instructions**

| Instruction | Addrossing Mode | Bytes | Cycles | Flags |   |
|-------------|-----------------|-------|--------|-------|---|
| instruction | Addressing Mode | Bytes | Cycles | Z     | С |
| NOP         | Inherent        | 1     | 2      | *     | * |
| RET         | Inherent        | 1     | 2      | *     | * |
| RETI        | Inherent        | 1     | 2      | Δ     | Δ |
| STOP (1)    | Inherent        | 1     | 2      | *     | * |
| WAIT        | Inherent        | 1     | 2      | *     | * |

Notes:

1. This instruction is deactivated and a WAIT is automatically executed instead of a STOP if the Watchdog function is selected.

 $\Delta$  . Affected

\* . Not Affected

#### Table 18. Jump & Call Instructions

| Instruction | Addressing Mode | Bytes | Civalaa | Flags |   |  |
|-------------|-----------------|-------|---------|-------|---|--|
| Instruction |                 |       | Cycles  | Z     | С |  |
| CALL abc    | Extended        | 2     | 4       | *     | * |  |
| JP abc      | Extended        | 2     | 4       | *     | * |  |

Notes:

abc.12-bit address; . Not Affected



rr. Data space register

Not Affected

Affected

Δ. \*

\* . Not Affected

### Opcode Map Summary. The following table contains an opcode map for the instructions used on the MCU.

| Low       |                        |                 |                        | •                    |                       | _           | _                     | _               | _                      | _                    |                        | _                     | _                     |                      | _                     | _                     | LOW       |
|-----------|------------------------|-----------------|------------------------|----------------------|-----------------------|-------------|-----------------------|-----------------|------------------------|----------------------|------------------------|-----------------------|-----------------------|----------------------|-----------------------|-----------------------|-----------|
|           | 0000                   | 1<br>0001       | 0010                   | 3<br>0011            | 4<br>0100             | 5<br>0101   | 6<br>0110             | 7<br>0111       | 8<br>1000              | 9<br>1001            | A<br>1010              | В<br>1011             | С<br>1100             | D<br>1101            | E<br>1110             | F<br>1111             |           |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |             | 2 JRC                 | 4 LD            | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 4 LDI                | 2 JRC                 | 4 LD                  | <u> </u>  |
| 0         | е                      | abc             | е                      | b0,rr,ee             | e                     | #           | е                     | a,(x)           | e                      | abc                  | e                      | b0.rr                 | e                     | rr,nn                | e                     | a,(y)                 | 0         |
| 0000      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |             | 1 prc                 | 1 ind           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | · ·                  | 1 pcr                 | 1 ind                 | 0000      |
|           | 2 <b>JRNZ</b>          | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 <b>JRZ</b>          | 4 INC       | 2 JRC                 | 4 LDI           | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 DEC                | 2 JRC                 | 4 LD                  |           |
| 1         | е                      | abc             | е                      | b0,rr,ee             | е                     | x           | е                     | a,nn            | е                      | abc                  | е                      | b0,rr                 | е                     | x                    | е                     | a, rr                 |           |
| 0001      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 | 2 imm           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd                 | 1 pcr                 | 2 dir                 | 0001      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |             | 2 JRC                 | 4 CP            | 2 JRNZ                 | 4 JP                 | 2 JRNC                 |                       | 2 JRZ                 | 4 COM                | 2 JRC                 | 4 CP                  |           |
| 2<br>0010 | е                      | abc             | е                      | b4,rr,ee             | е                     | #           | е                     | a,(x)           | е                      | abc                  | е                      | b4,rr                 | е                     | а                    | е                     | a,(y)                 | 2<br>0010 |
| 0010      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |             | 1 prc                 | 1 ind           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh                | 1 pcr                 | 1 ind                 | 0010      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 LD        | 2 JRC                 | 4 CPI           | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 LD                 | 2 JRC                 | 4 CP                  |           |
| 3<br>0011 | е                      | abc             | е                      | b4,rr,ee             | е                     | a,x         | е                     | a,nn            | е                      | abc                  | е                      | b4,rr                 | е                     | x,a                  | е                     | a, rr                 | 3<br>0011 |
| 0011      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 | 2 imm           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d.                | 1 pcr                 | 1 sd                 | 1 pcr                 | 2 dir                 |           |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |             | 2 JRC                 | 4 ADD           | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 2 RETI               | 2 JRC                 | 4 ADD                 |           |
| 4<br>0100 | е                      | abc             | е                      | b2,rr,ee             | е                     | #           | е                     | a,(x)           | е                      | abc                  | е                      | b2,rr                 | е                     |                      | е                     | a,(y)                 | 4<br>0100 |
| 0100      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |             | 1 prc                 | 1 ind           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh                | 1 pcr                 | 1 ind                 | 0100      |
| _         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 INC       | 2 JRC                 | 4 ADDI          | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 DEC                | 2 JRC                 | 4 ADD                 | _         |
| 5<br>0101 | е                      | abc             | е                      | b2,rr,ee             | е                     | У           | е                     | a,nn            | е                      | abc                  | е                      | b2,rr                 | е                     | У                    | е                     | a, rr                 | 5<br>0101 |
| 0101      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 | 2 imm           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd                 | 1 pcr                 | 2 dir                 | 0.01      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |             | 2 JRC                 | 4 INC           | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 2 STOP               | 2 JRC                 | 4 INC                 |           |
| 6<br>0110 | е                      | abc             | е                      | b6,rr,ee             | е                     | #           | е                     | (x)             | е                      | abc                  | е                      | b6,rr                 | е                     |                      | е                     | (y)                   | 6<br>0110 |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |             | 1 prc                 | 1 ind           | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 |                      | 1 pcr                 | 1 ind                 | ••        |
| -         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 LD        | 2 JRC                 |                 | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 LD                 | 2 JRC                 | 4 INC                 | 7         |
| 7<br>0111 | е                      | abc             | е                      | b6,rr,ee             | е                     | a,y         | е                     | #               | е                      | abc                  | е                      | b6,rr                 | е                     | y,a                  | е                     | rr                    | 0111      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 |                 | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 sd                 | 1 pcr                 | 2 dir                 |           |
| 8         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |             | 2 JRC                 |                 | 2 JRNZ                 | -                    | 2 JRNC                 | 4 RES                 | 2 JRZ                 |                      | 2 JRC                 | 4 LD                  | 8         |
| 1000      | е                      | abc             | е                      | b1,rr,ee             | е                     | #           | е                     | (x),a           | е                      | abc                  | е                      | b1,rr                 | е                     | #                    | е                     | (y),a                 | 1000      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |             | 1 prc                 | 1 ind           |                        | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 |                      | 1 pcr                 | 1 ind                 |           |
| 9         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 INC       | 2 JRC                 |                 | 2 JRNZ                 | 4 <b>JP</b>          | 2 JRNC                 | 4 SET                 | 2 JRZ                 | -                    | 2 JRC                 | 4 LD                  | 9         |
| 1001      | e                      | abc             | е                      | b1,rr,ee             | e                     | v .         | e                     | #               | е                      | abc                  | е                      | b1,rr                 | е                     | v                    | е                     | rr,a                  | 1001      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 |                 | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 |                      | 1 pcr                 | 2 dir                 |           |
| Α         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |             | 2 JRC                 | 4 AND           | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 | 4 RLC                | 2 JRC                 | 4 AND                 |           |
| 1010      | e                      | abc             | e                      | b5,rr,ee             | e                     | #           | e                     | a,(x)           | e                      | abc                  | е                      | b5,rr                 | е                     | a                    | е                     | a,(y)                 | 1010      |
|           | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 CALL | 1 pcr<br>2 <b>JRNC</b> | 3 bt<br>5 <b>JRS</b> | 1 pcr<br>2 <b>JRZ</b> | 4 LD        | 1 prc<br>2 <b>JRC</b> | 1 ind<br>4 ANDI | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 JP        | 1 pcr<br>2 <b>JRNC</b> | 2 b.d<br>4 <b>SET</b> | 1 pcr<br>2 <b>JRZ</b> | 1 inh<br>4 LD        | 1 pcr<br>2 <b>JRC</b> | 1 ind<br>4 <b>AND</b> |           |
| в         | ∠ JRNZ<br>e            | 4 CALL<br>abc   | 2 JKNC<br>e            | b5.rr.ee             | 2 JRZ                 | 4 LD<br>a.v | 2 JRC                 |                 |                        |                      |                        | -                     | -                     |                      |                       |                       | в         |
| 1011      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | a,v<br>1 sd | 1 prc                 | a,nn<br>2 imm   | e                      | abc<br>2 ext         | e<br>1 nor             | b5,rr<br>2 b.d        | e<br>1 nor            | v,a                  | e<br>1 nor            | a,rr<br>2 dir         | 1011      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 | 1 50        | 2 JRC                 |                 | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 <b>JP</b> | 1 pcr<br>2 <b>JRNC</b> |                       | 1 pcr<br>2 <b>JRZ</b> | 1 sd<br>2 <b>RET</b> | 1 pcr<br>2 <b>JRC</b> | 2 uii<br>4 SUB        |           |
| с         | 2 JKN2<br>e            | abc             | e                      | b3,rr,ee             | 2 <b>3112</b>         | #           | 2 JKC                 | a,(x)           | e 2 JKINZ              | 4 JF                 | 2 JKNC<br>e            | 4 KES<br>b3,rr        | 2 JKZ                 |                      | 2 JKC                 | 4 30B<br>a,(y)        | l c       |
| 1100      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | "           | 1 prc                 | 1 ind           |                        | 2 ext                |                        | 2 b.d                 | -                     | 1 inh                |                       | 1 ind                 | 1100      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 INC       | 2 JRC                 | 4 SUBI          | 1 pcr<br>2 <b>JRNZ</b> | 2 ext                | 1 pcr<br>2 <b>JRNC</b> |                       | 1 pcr<br>2 <b>JRZ</b> |                      | 1 pcr<br>2 <b>JRC</b> | 4 SUB                 |           |
| D         | e                      | abc             | e                      | b3,rr,ee             | e 0112                | - 110<br>w  | e 612                 | a,nn            | e                      | abc                  | e                      | b3.rr                 | 2 <b>3 1 2</b>        | w W                  | 2 JKC                 | a,rr                  | D         |
| 1101      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 |                 | 1 pcr                  |                      | 1 pcr                  | 2 b.d                 | 1 pcr                 |                      | 1 pcr                 | 2 dir                 | 1101      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 | . 50        | 2 JRC                 |                 | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2 JRZ                 |                      | 2 JRC                 | 4 DEC                 |           |
| Е         | e                      | abc             | e                      | b7.rr.ee             | e                     | #           | e                     | (x)             | e                      | abc                  | e                      | b7,rr                 | e 0112                |                      | e e                   | (y)                   | E         |
| 1110      |                        | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |             | 1 prc                 | 1 ind           | -                      | 2 ext                | 1 pcr                  | 2 b.d                 | 1 pcr                 | 1 inh                | 1 pcr                 | 1 ind                 | 1110      |
| <u> </u>  | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 LD        | 2 JRC                 | -               | 2 JRNZ                 | 2 CA                 | 2 JRNC                 | 4 SET                 | 2 JRZ                 | 4 LD                 | 2 JRC                 | 4 DEC                 |           |
| F         | e                      | abc             | e                      | b7,rr,ee             | e                     | a,w         | e                     | #               | e                      | abc                  | e                      | b7,rr                 | e                     | w,a                  | e                     | rr                    | F         |
| 1111      |                        | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd        | 1 prc                 |                 | 1 pcr                  |                      | 1 pcr                  | - '                   | 1 pcr                 |                      | 1 pcr                 | 2 dir                 | 1111      |
|           |                        | -74             |                        |                      |                       | 50          |                       | i               |                        | 5/11                 |                        |                       |                       |                      |                       |                       |           |

Abbreviations for Addressing Modes:

- dir Direct
- Short Direct sd imm Immediate
- Inherent inh
- Extended ext
- b.d Bit Direct
- bt Bit Test
- Program Counter Relative Indirect pcr ind

#### Legend:

Indicates Illegal Instructions #

е 5 Bit Displacement

- b 3 Bit Address
- 1byte dataspace address 1 byte immediate data rr
- nn
- abc 12 bit address
- ee 8 bit Displacement

2 JRC - Mnemonic Cycles Operand • е 1 Bytes\* pcr Addressing Mode

130/232



### **ELECTRICAL CHARACTERISTICS**

#### **Absolute Maximum Ratings**

This product contains devices to protect the inputs against damage due to high static voltages, however it is advised to take normal precaution to avoid application of any voltage higher than maximum rated voltages.

For proper operation it is recommended that V<sub>I</sub> and V<sub>O</sub> must be higher than V<sub>SS</sub> and smaller than V<sub>DD</sub>. Reliability is enhanced if unused inputs are connected to an appropriated logic voltage level (V<sub>DD</sub> or V<sub>SS</sub>).

**Power Considerations.** The average chip-junction temperature, Tj, in Celsius can be obtained from:

 $T_j = T_A + PD x RthJA$ 

Where  $:T_A =$  Ambient Temperature.

RthJA = Package thermal resistance (junction-to ambient).

PD = Pint + Pport.

Pint = IDD x VDD (chip internal power).

Pport = Port power dissipation (determinated by the user).

| Symbol           | Parameter                                                         | Value                                          | Unit |
|------------------|-------------------------------------------------------------------|------------------------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                                                    | -0.3 to 7.0                                    | V    |
| V <sub>LCD</sub> | Display Voltage                                                   | -0.3 to 11.0                                   | V    |
| VI               | Input Voltage                                                     | V <sub>SS</sub> - 0.3 to V <sub>DD</sub> + 0.3 | V    |
| Vo               | Output Voltage                                                    | $V_{SS}$ - 0.3 to $V_{DD}$ + 0.3               | V    |
| lo               | Current Drain per Pin Excluding V <sub>DD</sub> & V <sub>SS</sub> | ± 10                                           | mA   |
| IV <sub>DD</sub> | Total Current into V <sub>DD</sub> (source)                       | 50                                             | mA   |
| IV <sub>SS</sub> | Total Current out of V <sub>SS</sub> (sink)                       | 50                                             | mA   |
| Tj               | Junction Temperature                                              | 150                                            | °C   |
| T <sub>STG</sub> | Storage Temperature                                               | -60 to 150                                     | °C   |

Note : Stresses above those listed as "absolute maximum ratings" may cause permanent damage to the device . This is a stress rating only and functional operation of the device at these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

#### THERMAL CHARACTERISTIC

| Symbol | Parameter          | eter Test Conditions |      | Value |      |      |  |
|--------|--------------------|----------------------|------|-------|------|------|--|
| Symbol | i urumotoi         |                      | Min. | Тур.  | Max. | Unit |  |
| RthJA  | Thermal Resistance | PQFP64               |      | 70    |      | °C/W |  |

#### **RECOMMENDED OPERATING CONDITIONS**

| Symbol           | Parameter                | Test Condition s                     |          | Unit |          |      |
|------------------|--------------------------|--------------------------------------|----------|------|----------|------|
| Gymbol           |                          | rest conditions                      | Min.     | Тур. | Max.     | onic |
| T <sub>A</sub>   | Operating Temperature    | 1 Suffix Version<br>6 Suffix Version | 0<br>-40 |      | 70<br>85 | °C   |
| V <sub>DD</sub>  | Operating Supply Voltage |                                      | 3        |      | 6        | V    |
| V <sub>LCD</sub> | Display Voltage          |                                      | 3        |      | 10       | V    |
| V <sub>DD</sub>  | RAM Retention Voltage    |                                      | 2        |      |          | V    |



#### **RECOMMENDED OPERATING CONDITIONS** (Continued)

| Symbol            | Parameter                                                                                       | Test Condition s                        |              |      | Unit       |      |
|-------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------|--------------|------|------------|------|
| Symbol            | rarameter                                                                                       | rest conditions                         | Min.         | Тур. | Max.       | Onic |
| fosc              | Oscillator Frequency <sup>(1)(4)</sup>                                                          | $V_{DD} \ge 4.5V$<br>$V_{DD} \ge 3V$    | 0.01<br>0.01 |      | 8.388<br>2 | MHz  |
| I <sub>INJ+</sub> | Pin Injection Current (positive)<br>Digital Input <sup>(2)</sup><br>Analog Input <sup>(3)</sup> | $V_{DD} = 4.5 \text{ to } 5.5 \text{V}$ |              |      | +5         | mA   |
| I <sub>INJ-</sub> | Pin Injection Current (negative)<br>Digital Input <sup>(2)</sup><br>Analog Input                | $V_{DD} = 4.5 \text{ to } 5.5 \text{V}$ |              |      | -5         | mA   |

Notes :

An oscillator frequency above 1MHz is recommanded for reliable A/D results.
 A current of ± 5mA can be forced on each pin of the digital section without affecting the functional behaviour of the device. For a positive current injected into one pin, a part of this current (~ 10%) can be expected to flow from the neighbouring pins. A current of -5mA can be forced on one input of the analog section at a time (or -2.5mA for all inputs at a time) without affecting the conversion.
 If a total current of +1mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 1mA, all the conversion is resulting shifted of +1LSB. If a total positive current of +5mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 5mA, all the conversion is resulting shifted of +2LSB.
 Operation below 0.01 MHz is possible but requires increased supply current.

#### **EEPROM INFORMATION**

The ST62xx EEPROM single poly process has been specially developed to achieve 300.000 Write/Erase cycles and a 10 years data retention.

#### DC ELECTRICAL CHARACTERISTICS

(T<sub>A</sub> = -40 to +85°C unless otherwise specified)

| Symbol          | Parameter                                | Test Conditions                                                                                                                                                                                                                                             |                     | Value |                    | Unit           |
|-----------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------|--------------------|----------------|
| Symbol          |                                          | Test conditions                                                                                                                                                                                                                                             | Min.                | Тур.  | Max.               | onit           |
| VIL             | Input Low Level Voltage                  | RESET, NMI, TIMER,<br>WDON Pin                                                                                                                                                                                                                              |                     |       | 0.3V <sub>DD</sub> | V              |
|                 |                                          | TIMER                                                                                                                                                                                                                                                       | 0.80V <sub>DD</sub> |       |                    | V              |
| V <sub>IH</sub> | V <sub>IH</sub> Input High Level Voltage | RESET, NMI,<br>WDON Pin                                                                                                                                                                                                                                     | 0.70V <sub>DD</sub> |       |                    | V              |
| Іц<br>Ін        | Input Leakage Current                    | $\begin{array}{l} \text{RESET Pin} \\ \text{V}_{\text{DD}} = 5\text{V} \\ \text{V}_{\text{IN}} = \text{V}_{\text{DD}} \ ^{(1)} \\ \text{V}_{\text{IN}} = \text{V}_{\text{DD}} \ ^{(2)} \\ \text{V}_{\text{IN}} = \text{V}_{\text{SS}} \ ^{(5)} \end{array}$ |                     |       | 10<br>1<br>50      | μA<br>mA<br>μA |
| V <sub>OL</sub> | Low Level Output Voltage                 | TIMER, $I_{OL} = 5.0 \text{mA}$                                                                                                                                                                                                                             |                     |       | 0.2V <sub>DD</sub> | V              |
| V <sub>OH</sub> | High Level Output Voltage                | TIMER, I <sub>OL</sub> = -5.0mA                                                                                                                                                                                                                             | 0.65V <sub>DD</sub> |       |                    | v              |
| R <sub>PU</sub> | Pull-up Resistor                         | V <sub>IN</sub> =0V V <sub>DD</sub> =5V<br>WDON - NMI                                                                                                                                                                                                       | 40                  | 100   | 200                | kΩ             |
|                 |                                          | RESET                                                                                                                                                                                                                                                       | 200                 | 300   | 500                | kΩ             |

Notes on next page



# **DC ELECTRICAL CHARACTERISTICS** (Continued) $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwise specified})$

| Symbol                             | Parameter                               | Test Conditions                                                                                 |      | Value |            | Unit |
|------------------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------|------|-------|------------|------|
| Symbol                             | Farameter                               | Test conditions                                                                                 | Min. | Тур.  | Max.       | Onic |
| I <sub>IL</sub><br>I <sub>IH</sub> | Input Leakage Current                   | TIMER<br>V <sub>IN</sub> = V <sub>DD</sub> or V <sub>SS</sub>                                   |      | 0.1   | 1.0        | μA   |
| I <sub>LL</sub><br>Iн              | Input Leakage Current                   | $\begin{split} & NMI \\ & VDD = 5V \\ & V_{IN} = V_{SS}^{(5)} \\ & V_{IN} = V_{DD} \end{split}$ |      |       | 100<br>1.0 | μΑ   |
| I∟<br>Iıн                          | Input Leakage Current                   | $WDON VDD = 5V V_{IN} = V_{SS} (5) V_{IN} = V_{DD}$                                             |      |       | 100<br>1.0 | μΑ   |
|                                    | Supply Current RUN Mode                 | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$                                        |      | 4     | 7          | mA   |
| I <sub>DD</sub>                    | Supply Current WAIT Mode <sup>(4)</sup> | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$                                        |      | 1     | 2          | mA   |
|                                    | Supply Current RESET Mode               | fosc = 8MHz,<br>V <sub>RESET</sub> = V <sub>SS</sub>                                            |      | 1     | 7          | mA   |
|                                    | Supply Current STOP Mode (3)(4)         | I <sub>LOAD</sub> = 0mA<br>V <sub>DD</sub> = 5.0V                                               |      | 1     | 10         | μΑ   |

 Notes :

 1. No Watchdog Reset activated.

 2. Reset generated by Watchdog.

 3. When the watchdog function is actvated the STOP instruction is deactivated. WAIT instruction is automatically executed.

 4. All on-chip peripherals in OFF state

 5. Pull-up resistor



## ST6242

#### **CURRENT CONSUMPTION**





#### **AC ELECTRICAL CHARACTERISTICS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                           | Test Condition s                                                    |         | Value          |            | Unit   |
|------------------|-------------------------------------|---------------------------------------------------------------------|---------|----------------|------------|--------|
| Symbol           | Falameter                           | rest conditions                                                     | Min.    | Тур.           | Max.       |        |
| fosc             | Oscillator Frequency <sup>(2)</sup> | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01    |                | 8.388<br>2 | MHz    |
| ts∪              | Oscillator Start-up Time            | $C_{L1} = C_{L2} = 22pF - crystal$                                  |         | 5              | 20         |        |
| t <sub>SR</sub>  | Supply Rise Time                    | 10% to 90%                                                          | 0.01    |                | 100        | ms     |
| t <sub>REC</sub> | Supply Recovery Time <sup>(1)</sup> |                                                                     | 100     |                |            |        |
| Tw               | Minimum Pulse Width                 | NMI Pin<br>V <sub>DD</sub> = 5V                                     | 100     |                |            | ns     |
|                  |                                     | RESET Pin                                                           | 100     |                |            | ns     |
| T <sub>WEE</sub> | EEPROM Write Time                   | $T_A = 25^{\circ}C$ One Byte<br>$T_A = 85^{\circ}C$ One Byte        |         | 5<br>15        | 10<br>25   | ms     |
| Endurance        | EEPROM WRITE/ERASE<br>Cycles        | Q <sub>A</sub> L <sub>OT</sub><br>Acceptance Criteria               | 300.000 | > 1<br>million |            | cycles |
| Retention        | EEPROM Data Retention               | $T_A = 55^{\circ}C$                                                 | 10      |                |            | years  |
| C <sub>IN</sub>  | Input Capacitance                   | All Inputs Pins                                                     |         |                | 10         | pF     |
| C <sub>OUT</sub> | Output Capacitance                  | All Outputs Pins                                                    |         |                | 10         | pF     |

Notes:

Period for which V<sub>DD</sub> has to be connected or at 0V to allow internal Reset function at next power-up.
 Operation below 0.01 MHz is possible but requires increased supply current.





#### I/O PORTS

(T<sub>A</sub> = -40 to +85°C unless otherwise specified)

| Symbol                 | Parameter                 | Test Condition s                                                 |                      | Value |                      | Unit |
|------------------------|---------------------------|------------------------------------------------------------------|----------------------|-------|----------------------|------|
| Symbol                 | Farameter                 | Test Condition's                                                 | Min.                 | Тур.  | Max.                 | Onit |
| V <sub>IL</sub>        | Input Low Level Voltage   | I/O Pins                                                         |                      |       | 0.3V <sub>DD</sub>   | V    |
| VIH                    | Input High Level Voltage  | I/O Pins                                                         | $0.7V_{DD}$          |       |                      | V    |
|                        |                           | I/O Pins,<br>I <sub>O</sub> = 10μA (sink)                        |                      |       | 0.1                  | V    |
|                        | Low Level Output Voltage  | I/O Pins, $I_{OL} = V_{DD}x1mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |       | 0.16xV <sub>DD</sub> | V    |
|                        |                           | $I/O$ Pins, $I_{OL} = 1.6mA$<br>$V_{DD} = 3V$                    |                      |       | 0.4                  | V    |
| V <sub>OL</sub>        |                           | I/O Pins, $I_{OL} = V_{DD}x2mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |       | 0.16xV <sub>DD</sub> | V    |
|                        | Low Level Output Voltage, | I/O Pins, $I_{OL} = 3.2mA$<br>$V_{DD} = 3V$                      |                      |       | 0.4                  | V    |
|                        | PB4-PB7 Only              | I/O Pins, $I_{OL} = V_{DD}x4mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |       | 0.26xV <sub>DD</sub> | V    |
|                        |                           | I/O Pins, $I_{OL} = 6.4mA$<br>$V_{DD} = 3V$                      |                      |       | 0.8                  | V    |
| Vон                    | High Level Output Voltage | I/O Pins,<br>I <sub>O</sub> = -10μA (source)                     | V <sub>DD</sub> -0.1 |       |                      | V    |
| VOH                    |                           | I/O Pins, $I_{OL} = -V_{DD}x1mA$<br>$V_{DD} = 5.0V$              | 0.6xV <sub>DD</sub>  |       |                      | V    |
| I <sub>IL</sub><br>IIH | Input Leakage Current     | I/O Pins, <sup>(1)</sup>                                         |                      | 0.1   | 1.0                  | μΑ   |
| R <sub>PU</sub>        | Pull-up Resistor          | I/O Pins<br>V <sub>IN</sub> = 0V, V <sub>DD</sub> = 5.0V         | 40                   | 100   | 200                  | KΩ   |

Note 1. Pull-up resistor off

## SPI ELECTRICAL CHARACTERISTICS

(V\_DD = 5.0 V, T\_A = -40 to +85  $^\circ C$  unless otherwhise specified)

| Symbol          | Parameter       | Test Conditions    |      | Unit |      |      |
|-----------------|-----------------|--------------------|------|------|------|------|
|                 |                 | resconditions      | Min. | Тур. | Max. | onic |
| F <sub>CL</sub> | Clock Frequency | applied on PB5/SCL |      |      | 1    | MHz  |
| t <sub>SU</sub> | Set-up Time     | applied on PB6/Sin |      | 50   |      | ns   |
| t <sub>h</sub>  | Hold Time       | applied on PB6/Sin |      | 100  |      | ns   |



#### **A/D CONVERTER CHARACTERISTICS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                          | Parameter                                 | Test Conditions                                        |      | Value |           | Unit |
|---------------------------------|-------------------------------------------|--------------------------------------------------------|------|-------|-----------|------|
| Gymbol                          | i arameter                                |                                                        | Min. | Тур.  | Max.      | onit |
| Res                             | Resolution (3)                            |                                                        |      | 8     |           | Bit  |
| A <sub>TOT</sub>                | Total Accuracy (3)                        | f <sub>OSC</sub> > 1.2 MHz<br>f <sub>OSC</sub> > 32kHz |      |       | ± 2<br>±4 | LSB  |
| tc <sup>(1)</sup>               | Conversion Time                           | f <sub>OSC</sub> = 8MHz                                |      | 70    |           | μs   |
| Van                             | Conversion Range                          |                                                        | Vss  |       | Vdd       | V    |
| ZIR                             | Zero Input Reading                        | Conversion result when $V_{IN} = V_{SS}$               | 00   |       |           | Hex  |
| FSR                             | Full Scale Reading                        | Conversion result when $V_{IN} = V_{DD}$               |      |       | FF        | Hex  |
| ADı                             | Analog Input Current During<br>Conversion | V <sub>DD</sub> = 4.5V                                 |      |       | 1.0       | μΑ   |
| AC <sub>IN</sub> <sup>(2)</sup> | Analog Input Capacitance                  |                                                        |      | 2     | 5         | pF   |
| ASI                             | Analog Source Impedance                   |                                                        |      |       | 30        | kΩ   |
| SSI                             | Analog Reference Supply<br>Impedence      |                                                        |      |       | 2         | kΩ   |

With oscillator frequencies less than 1MHz, the A/D Converter accuracy is decreased.
 Excluding Pad Capacitance
 Noise at V<sub>DD</sub>,V<sub>SS</sub> ≤ 10mV



#### TIMER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwise specified})$ 

| Symbol           | Parameter                    | Test Conditions                      |                      | Unit |                  |          |
|------------------|------------------------------|--------------------------------------|----------------------|------|------------------|----------|
|                  | i didineter                  |                                      | Min.                 | Тур. | Max.             | Onic     |
| t <sub>RES</sub> | Resolution                   |                                      | $\frac{12}{f_{OSC}}$ |      |                  | second   |
| fın              | Input Frequency on TIMER Pin |                                      |                      |      | <u>fosc</u><br>8 | MHz      |
| tw               | Pulse Width at TIMER Pin     | $V_{DD} \ge 3V$<br>$V_{DD} \ge 4.5V$ | 1<br>125             |      |                  | μs<br>ns |

### LCD ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                        | Test Conditions                              | Value |      |      | Unit |  |
|------------------|----------------------------------|----------------------------------------------|-------|------|------|------|--|
| Gymbol           | i alametei                       | resconditions                                | Min.  | Тур. | Max. | 0.mc |  |
| f <sub>FR</sub>  | Frame Frequency                  | 1/4 Duty<br>f <sub>OSC</sub> = 1, 2, 4, 8MHz | 16    |      | 128  | Hz   |  |
| V <sub>OS</sub>  | DC Offset Voltage <sup>(1)</sup> | $V_{LCD} = V_{DD}$ , no load                 |       |      | 50   | mV   |  |
| V <sub>OH</sub>  | COM High Level, Output Voltage   | $I=100\mu A, V_{LCD}=5V$                     | 4.5V  |      |      | V    |  |
| V <sub>OL</sub>  | COM Low Level, Output Voltage    | $I = 100 \mu A, \ V_{LCD} = 5 V$             |       |      | 0.5V | V    |  |
| V <sub>OH</sub>  | SEG High Level, Output Voltage   | $I = 50 \mu A, V_{LCD} = 5 V$                | 4.5V  |      |      | V    |  |
| V <sub>OL</sub>  | SEG Low Level, Output Voltage    | $I = 50 \mu A, V_{LCD} = 5 V$                |       |      | 0.5V | V    |  |
| V <sub>LCD</sub> | Display Voltage                  | Note 2                                       | 3     |      | 10   | V    |  |

Notes :
1. The DC offset voltage refers to all segment and common outputs. It is the difference between the measured voltage value and nominal value for every voltage level. Ri of voltage meter must be greater than or equal to 100MΩ.
2. An external resistances network is required when V<sub>LCD</sub> ≤ 4.5V.



### PACKAGE MECHANICAL DATA

#### Figure 49. ST6242 64 Pin Plastic Quad Flat Pack Package





## ST6242



## Recommended Solder Pad Footprint For QFP64 (in mm)



#### **ORDERING INFORMATION**

The following chapter deals with the procedure for transfer the Program/Data ROM codes to SGS-THOMSON.

**Communication of the ROM Codes.** To communicate the contents of Program/Data ROM memories to SGS-THOMSON, the customer has to send :

- one file in INTEL INTELLEC 8/MDS FORMAT (in an MS-DOS 5" diskette) for the PROGRAM Memory
- one file in INTEL INTELLEC 8/MDS FORMAT (in a MS-DOS 5" diskette) for the EEPROM initial content (this file is optional)
- a filled Option List form as described in the OPTION LIST paragraph.

The program ROM should respect the ROM Memory Map as in Table 19.

The ROM code must be generated with ST6 assembler. Before programming the EPROM, the buffer of the EPROM programmer must be filled with FFh.

| ROM Page           | Device Address                                                                         | Description                                                                         |  |  |
|--------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|--|
| Page 0             | 0000h-007Fh<br>0080h-07FFh                                                             | Reserved<br>User ROM                                                                |  |  |
| Page 1<br>"STATIC" | 0800h-0F9Fh<br>0FA0h-0FEFh<br>0FF0h-0FF7h<br>0FF8h-0FFBh<br>0FFCh-0FFDh<br>0FFEh-0FFFh | User ROM<br>Reserved<br>Interrupt Vectors<br>Reserved<br>NMI Vector<br>Reset Vector |  |  |
| Page 2             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                |  |  |
| Page 3             | 0000h-000Fh<br>0010h-07FFh                                                             | Reserved<br>User ROM                                                                |  |  |

 Table 19. ROM Memory Map

Note : EPROM addresses are related to the ROM file to be processed.

## Customer EEPROM Initial Contents : Format

a. The content should be written into an INTEL INTELLEC format file.

b. In the case of 128 bytes of EEPROM, the starting address in 000h and the end in 7Fh.

c. Undefined or don't care bytes should have the content FFh.

Listing Generation & Verification. When SGS-THOMSON receives the Codes, they are compared and a computer listing is generated from them. This listing refers exactly to the mask that will be used to produce the microcontroller. Then the listing is returned to the customer that must thoroughly check, complete, sign and return it to SGS-THOMSON. The signed list constitutes a part of the contractual agreement for the creation of the customer mask. SGS-THOMSON sales organization will provide detailed information on contractual points.

#### **ORDERING INFORMATION TABLE**

| Sales Types | Temperature Range | Package |  |
|-------------|-------------------|---------|--|
| ST6242Q1/XX | 0 to + 70°C       | PQFP64  |  |
| ST6242Q6/XX | -40 to + 85°C     | PQFP64  |  |

Note : "XX" is the ROM code identifier allocated by SGS-THOMSON after receipt of all required options and the related ROM file.



| ST6242 MICROCONTROLLER OPTION LIST                          |                                                                                                                               |  |  |  |  |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Customer                                                    |                                                                                                                               |  |  |  |  |
| Address                                                     |                                                                                                                               |  |  |  |  |
| Contact                                                     |                                                                                                                               |  |  |  |  |
| Phone No                                                    |                                                                                                                               |  |  |  |  |
| Reference                                                   |                                                                                                                               |  |  |  |  |
|                                                             |                                                                                                                               |  |  |  |  |
| SGS-THOMSON Micro                                           | pelectronics references                                                                                                       |  |  |  |  |
| Device<br>Package<br>Temperature Range                      | <ul> <li>[ ] ST6242</li> <li>[ ] Plastic Quad Flat Package</li> <li>[ ] 0°C to + 70°C</li> <li>[ ] -40°C to + 85°C</li> </ul> |  |  |  |  |
| Special Marking                                             | [ ] No<br>[ ] Yes ""                                                                                                          |  |  |  |  |
|                                                             | are Letters, digits, '.', '–', '/' and spaces only.<br>ith 10 characters maximum is possible.                                 |  |  |  |  |
| Comments :<br>- Number of LCD segm<br>- Number of LCD backp |                                                                                                                               |  |  |  |  |
| Note :                                                      |                                                                                                                               |  |  |  |  |
|                                                             |                                                                                                                               |  |  |  |  |
| Signature                                                   |                                                                                                                               |  |  |  |  |
| Date                                                        |                                                                                                                               |  |  |  |  |
|                                                             |                                                                                                                               |  |  |  |  |





## ST62E42 ST62T42

## 8-BIT OTP/EPROM HCMOS MCUs WITH LCD DRIVER, AND A/D CONVERTER

- 3 to 6V supply operating range
- 8.4MHz Maximum Clock Frequency
- Run, Wait & Stop Modes
- 5 different interrupt vectors
- Look-up table capability in EPROM

| User EPROM: | 7948 bytes |
|-------------|------------|
| Data RAM:   | 128 bytes  |
| LCD RAM:    | 24 bytes   |

- PQFP64 and CQFP64-W packages
- 10 fully software programmable I/O as:
  - Input with/without pull-up resistor
  - Input with interrupt generation
  - Open-Drain or Push-pull outputs
  - Analog Inputs (6 pins)
- 4 I/O lines can sink up to 20mA for direct LED or TRIAC driving and have SPI alternate functions
- 8-bit counters and 7-bit programmable prescalers
- Software activated digital watchdog
- 8-bit A/D converter with up to 6 analog inputs
- 8-bit synchronous serial peripheral interface (SPI)
- LCD driver with 40 segment outputs, 4 backplane outputs and selectable duty cycle for up to 160 LCD segments direct driving
- One external not maskable interrupt
- 9 powerful addressing modes
- The accumulator, the X, Y, V & W registers, the port and peripherals data & control registers are addressed in the data space as RAM locations.
- The ST62E42 is the EPROM version, ST62T42 is the OTP version, fully compatible with ST6242 ROM version.



April 1995

This is Preliminary data from SGS-THOMSON, details are subject to change without notice.

## ST62E42 - ST62T42



## Figure 1.Pin Quad Flat Pack (QFP) Package Pinout

#### ST62E42/T42 Pin Description

| Pin<br>number | Pin<br>name          | Pin<br>number | Pin<br>name             | Pin<br>number | Pin<br>name | Pin<br>number | Pin<br>name |
|---------------|----------------------|---------------|-------------------------|---------------|-------------|---------------|-------------|
| 1             | S45                  | 17            | V <sub>DD</sub>         | 33            | S13         | 49            | S29         |
| 2             | S46                  | 18            | V <sub>SS</sub>         | 34            | S14         | 50            | S30         |
| 3             | S47                  | 19            | RESET                   | 35            | S15         | 51            | S31         |
| 4             | S48                  | 29            | OSCout                  | 36            | S16         | 52            | S32         |
| 5             | COM4                 | 21            | OSCin                   | 37            | S17         | 53            | S33         |
| 6             | COM3                 | 22            | NMI                     | 38            | S18         | 54            | S34         |
| 7             | COM2                 | 23            | PB7/Sout <sup>(1)</sup> | 39            | S19         | 55            | S35         |
| 8             | COM1                 | 24            | PB6/Sin <sup>(1)</sup>  | 40            | S20         | 56            | S36         |
| 9             | VLCD1/3              | 25            | PB5/SCL <sup>(1)</sup>  | 41            | S21         | 57            | S37         |
| 10            | VLCD2/3              | 26            | PB4 <sup>(1)</sup>      | 42            | S22         | 58            | S38         |
| 11            | VLCD                 | 27            | PB3/Ain                 | 43            | S23         | 59            | S39         |
| 12            | PA7/Ain              | 28            | PB2/Ain                 | 44            | S24         | 60            | S40         |
| 13            | PA6/Ain              | 29            | S9                      | 45            | S25         | 61            | S41         |
| 14            | PA5/Ain              | 30            | S10                     | 46            | S26         | 62            | S42         |
| 15            | PA4/Ain              | 31            | S11                     | 47            | S27         | 63            | S43         |
| 16            | TEST/V <sub>PP</sub> | 32            | S12                     | 48            | S28         | 64            | S44         |

Note 1: 20mA SINK



# **GENERAL DESCRIPTION**

The ST62E42,T42 microcontrollers are members of the 8-bit HCMOS ST62xx family, a series of devices oriented to low-medium complexity applications. They are the EPROM/OTP versions of the ST6242 ROM device and are suitable for product prototyping and low volume production. All ST62xx members are based on a building block approach: a common core is associated with a combination of on-chip peripherals (macrocells). The macrocells of the ST6242 family are: a high performance LCD controller/driver with 40 segment outputs and 4 backplanes able to drive up to 160 segments, a Timer peripheral including an 8-bit counter with a 7-bit software programmable prescaler, a digital watchdog timer (DWD), an 8-bit A/D Converter with up to 6 analog inputs and an 8-bit synchronous Serial Peripheral Interface (SPI). Thanks to these peripherals the ST6242 family is well suited for general purpose, automotive, security, appliance and industrial applications.

Figure 2. ST62E42 Block Diagram



Note: Ain = Analog Input



# PIN DESCRIPTION

**V**<sub>DD</sub> and **V**<sub>SS</sub>. Power is supplied to the ST62E42 using these two pins. V<sub>DD</sub> is power and V<sub>SS</sub> is the ground connection.

**OSCin and OSCout**. These pins are internally connected with the on-chip oscillator circuit. A quartz crystal or a ceramic resonator can be connected between these two pins in order to allow the correct operation of the MCU with various stability/cost trade-offs. OSCin is the input pin, OSCout is the output pin. An external clock signal can be applied to OSCin.

**RESET.** The active low **RESET** pin is used to restart the microcontroller at the beginning of its program. The **RESET** pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TEST/VPP.** The TEST pin is used to place the MCU into special operating mode. TEST must be held at  $V_{SS}$  for normal operation (an internal pull-down resistor is present to select normal operating mode if TEST pin is not connected). If this pin is connected to a +12.5V level during the reset phase, the EPROM programming mode is entered.

**NMI.** The NMI pin provides the capability for asynchronous applying an external top priority interrupt to the ST62E42. This pin is falling edge sensitive. The NMI pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**PA4-PA7.** These 4 lines are organized as one I/O port (A). Each line may be configured under software control as an input with or without pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output or as analog input for the A/D converter. Port A has a 5mA drive capability in output mode.

**PB2-PB3,PB4-PB7.** These 6 lines are organized as one I/O port (B). Each line may be configured under software control as an input with or without internal pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output. PB2-PB3 can be programmed as analog inputs for the A/D converter while PB4-PB7 can also sink 20mA for direct LED driving. PB5-PB7 can also be used as respectively Clock, Data in and Data out pins for the on-chip SPI to carry the synchronous serial I/O signals.

**COM1-COM4.** These four pins are the LCD peripheral common outputs. They are the outputs of the on-chip backplane voltage generator which is used for multiplexing the 40 LCD lines allowing up to 160 segments to be driven.

**S9-S48.** These pins are the 40 LCD peripheral driver outputs of ST62E42. Segments S1-S8 are not connected to any pin.

**VLCD.** Display voltage supply. It determines the high voltage level on COM1-COM4 and S9-S48 pins.

VLCD1/3, VLCD2/3. Display supply voltage inputs for determining the display voltage levels on COM1-COM4 and S9-S48 pins during multiplex operation.



# ST62E42, T42 EPROM/OTP DESCRIPTION

The ST62E42 is the EPROM version of the ST6242 ROM product. It is intended for use during the development of an application, and for pre-production and small volume production. The ST62T42 OTP has the same characteristics. Both include EPROM memory instead of the ROM memory of the ST6242, and so the program and constants of the program can be easily modified by the user with the ST62E42 EPROM programming board from SGS-THOMSON.

From a user point of view (with the following exception) the ST62E42,T42 products have exactly the same software and hardware features of the ROM version. An additional mode is used to configure the part for programming of the EPROM, this is set by a +12.5V voltage applied to the TEST/V<sub>PP</sub> pin. The programming of the ST62E42,T42 is described in the User Manual of the EPROM Programming board.

On the ST62E42, all the 8192 bytes of PROGRAM memory are available for the user, as all the EPROM memory can be erased by exposure to UV light. On the ST62T42 (OTP) device) a reserved area for test purposes exists, as for the ST6242 ROM device. In order to avoid any discrepancy between program functionality when using the EPROM, OTP and ROM it is recommended not to use these reserved areas, even when using the ST62E42.

# Notes on programming:

In order to emulate exactly the ST6242 features with the ST62E42 and ST6242, some software precautions have to be taken:

1. Data RAM: The data entered in the Data RAM bank register (CBh) must be 08h.

2. I/O: To prevent floating input or uncontrolled I/O interrrupt on the EPROM/OTP devices, the port bits PA0-PA3, PB0, PB1 must be programmed as push-pull outputs.

3. Timer: The bit "TOUT" of the Timer status control register (D4h) must be set "1" (timer in output mode).

4. Data Memory Space: Write 40h at the address DFh of the Data Memory Space (desabled EE).

5. When programming for the EPROM/OTP parts, it is suggested that the conditional assembly technique is used for controlling the I/O ports in order to disable the appropriate code for the ROM device.

6. Do not access data space locations D5h, D6h, D7h, DAh, DBh.

Other than this exception, the ST62E42,T42 parts are fully compatible with the ROM ST6242 equivalent, this datasheet thus provides only information specific to the EPROM based devices.

#### THE READER IS ASKED TO REFER TO THE DATASHEET OF THE ST6242 ROM-BASED DE-VICE FOR FURTHER DETAILS.

# **EPROM ERASING**

The EPROM of the windowed package of the ST62E42 may be erased by exposure to Ultra Violet light.

The erasure characteristic of the ST62E42 EPROM is such that erasure begins when the memory is exposed to light with wave lengths shorter than approximately 4000Å. It should be noted that sunlight and some types of fluorescent lamps have wavelengths in the range 3000-4000Å. It is thus recommended that the window of the ST62E42 package be covered by an opaque label to prevent unintentional erasure problems when testing the application in such an environment.

The recommended erasure procedure of the ST62E42 EPROM is exposure to short wave ultraviolet light which has wavelength 2537Å. The integrated dose (i.e. UV intensity x exposure time) for erasure should be a minimum of 15 W-sec/cm<sup>2</sup>. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with 12000 $\mu$ W/cm<sup>2</sup> power rating. The ST62E42 should be placed within 2.5 cm (1 inch) of the lamp tubes during erasure.



# **ELECTRICAL CHARACTERISTICS**

# **Absolute Maximum Ratings**

This product contains devices to protect the inputs against damage due to high static voltages, however it is advised to take normal precaution to avoid application of any voltage higher than maximum rated voltages.

For proper operation it is recommended that  $V_I$  and  $V_O$  must be higher than  $V_{SS}$  and smaller than  $V_{DD}$ . Reliability is enhanced if unused inputs are connected to an appropriated logic voltage level ( $V_{DD}$  or  $V_{SS}$ ). **Power Considerations.** The average chip-junction temperature, Tj, in Celsius can be obtained from:

| Tj =              | T <sub>A</sub> + PD x RthJA                        |
|-------------------|----------------------------------------------------|
| Where : . $T_A =$ | Ambient Temperature.                               |
| RthJA =           | Package thermal resistance (junction-to ambient).  |
| PD = .            | Pint + Pport.                                      |
| Pint = .          | $I_{DD} \times V_{DD}$ (chip internal power).      |
| Pport =           | Port power dissipation (determinated by the user). |

| Symbol           | Parameter                                           | Value                              | Unit |
|------------------|-----------------------------------------------------|------------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                                      | -0.3 to 7.0                        | V    |
| V <sub>LCD</sub> | Display Voltage                                     | -0.3 to 11.0                       | V    |
| VI               | Input Voltage                                       | $V_{SS}$ - 0.3 to $V_{DD}$ + 0.3   | V    |
| Vo               | Output Voltage                                      | Vss - 0.3 to V <sub>DD</sub> + 0.3 | V    |
| lo               | Current Drain per Pin Excluding $V_{DD}$ & $V_{SS}$ | ± 10                               | mA   |
| IV <sub>DD</sub> | Total Current into V <sub>DD</sub> (source)         | 50                                 | mA   |
| IV <sub>SS</sub> | Total Current out of V <sub>SS</sub> (sink)         | 50                                 | mA   |
| Tj               | Junction Temperature                                | 150                                | °C   |
| T <sub>STG</sub> | Storage Temperature                                 | -60 to 150                         | °C   |

# THERMAL CHARACTERISTIC

| Symbol | Parameter          | Test Conditions    |      | Value    |      | Unit |
|--------|--------------------|--------------------|------|----------|------|------|
| Symbol | i arameter         | Test conditions    | Min. | Тур.     | Max. | Onit |
| RthJA  | Thermal Resistance | PQFP64<br>CQFP64-W |      | 70<br>70 |      | °C/W |

# **RECOMMENDED OPERATING CONDITIONS**

| Symbol           | Parameter                | Test Condition s                     |          | Unit |          |      |
|------------------|--------------------------|--------------------------------------|----------|------|----------|------|
| Symbol           | i arameter               | rest conditions                      | Min.     | Тур. | Max.     | Onic |
| T <sub>A</sub>   | Operating Temperature    | 1 Suffix Version<br>6 Suffix Version | 0<br>-40 |      | 70<br>85 | °C   |
| V <sub>DD</sub>  | Operating Supply Voltage |                                      | 3        |      | 6        | V    |
| V <sub>LCD</sub> | Display Voltage          |                                      | 3        |      | 10       | V    |
| V <sub>RM</sub>  | RAM Retention Voltage    |                                      | 2        |      |          | V    |

Note: Refer to ordering information at end of the datasheet.



# RECOMMENDED OPERATING CONDITIONS (Continued)

| Symbol            | Parameter                                                                                       | Test Condition s                     |              | Unit |            |      |
|-------------------|-------------------------------------------------------------------------------------------------|--------------------------------------|--------------|------|------------|------|
| Symbol            | i arameter                                                                                      | rest conditions                      | Min.         | Тур. | Max.       | Onic |
| fosc              | Oscillator Frequency <sup>(1)(4)</sup>                                                          | $V_{DD} \ge 4.5V$<br>$V_{DD} \ge 3V$ | 0.01<br>0.01 |      | 8.388<br>2 | MHz  |
| I <sub>INJ+</sub> | Pin Injection Current (positive)<br>Digital Input <sup>(2)</sup><br>Analog Input <sup>(3)</sup> | V <sub>DD</sub> = 4.5 to 5.5V        |              |      | +5         | mA   |
| I <sub>INJ-</sub> | Pin Injection Current (negative)<br>Digital Input <sup>(2)</sup><br>Analog Input                | V <sub>DD</sub> = 4.5 to 5.5V        |              |      | -5         | mA   |

Notes :

1. An oscillator frequency above 1MHz is recommanded for reliable A/D results.

2. A current of ± 5mA can be forced on each pin of the digital section without affecting the functional behaviour of the device. For a positive current injected into one pin, a part of this current (~ 10%) can be expected to flow from the neighbouring pins. A current of -5mA can be forced on one input of the analog section at a time (or -2.5mA for all inputs at a time) without affecting the conversion.

3. If a total current of +1mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 1mA, all the conversion is resulting shifted of +1LSB. If a total positive current of +5mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 5mA, all the conversion is resulting shifted of +2LSB.

4. Operation below 0.01 MHz is possible but requires increased supply current.

# **EEPROM INFORMATION**

The ST62xx EEPROM single poly process has been specially developed to achieve 300.000 Write/Erase cycles and a 10 years data retention.

# DC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                 | Parameter                 | Test Conditions                 |                     | Value |                    | Unit           |
|------------------------|---------------------------|---------------------------------|---------------------|-------|--------------------|----------------|
| Symbol                 |                           |                                 | Min.                | Тур.  | Max.               | Onic           |
| V <sub>IL</sub>        | Input Low Level Voltage   | RESET, NMI, TIMER,<br>WDON Pin  |                     |       | 0.3V <sub>DD</sub> | V              |
|                        |                           | TIMER                           | 0.80V <sub>DD</sub> |       |                    | V              |
| Vih                    | Input High Level Voltage  | RESET, NMI,<br>WDON Pin         | 0.70V <sub>DD</sub> |       |                    | V              |
| I <sub>IL</sub><br>IIH | Input Leakage Current     |                                 |                     |       | 10<br>1<br>50      | μA<br>mA<br>μA |
| V <sub>OL</sub>        | Low Level Output Voltage  | TIMER, I <sub>OL</sub> = 5.0mA  |                     |       | 0.2V <sub>DD</sub> | V              |
| V <sub>OH</sub>        | High Level Output Voltage | TIMER, I <sub>OL</sub> = -5.0mA | 0.65V <sub>DD</sub> |       |                    | V              |

Notes on next page



# DC ELECTRICAL CHARACTERISTICS (Continued) (TA = -40 to $+85^{\circ}$ C unless otherwise specified)

| Symbol                 | Parameter                                  | Test Conditions                                                  |      | Value |            | Unit |
|------------------------|--------------------------------------------|------------------------------------------------------------------|------|-------|------------|------|
| Symbol                 | Falanielei                                 |                                                                  | Min. | Тур.  | Max.       |      |
| R <sub>PU</sub>        | Pull-up Resistor                           | Vin=0V Vdd=5V<br>WDON - NMI                                      | 40   | 100   | 200        | kΩ   |
|                        |                                            | RESET                                                            | 200  | 300   | 500        | kΩ   |
| lıL<br>lih             | Input Leakage Current                      | TIMER<br>V <sub>IN</sub> = V <sub>DD</sub> or V <sub>SS</sub>    |      | 0.1   | 1.0        | μΑ   |
| I <sub>IL</sub><br>IIH | Input Leakage Current                      |                                                                  |      |       | 100<br>1.0 | μΑ   |
| lıL<br>lın             | Input Leakage Current                      | $WDON VDD = 5V V_{IN} = V_{SS} (5) V_{IN} = V_{DD}$              |      |       | 100<br>1.0 | μΑ   |
|                        | Supply Current RUN Mode                    | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$         |      | 4     | 7          | mA   |
| I <sub>DD</sub>        | Supply Current WAIT Mode (4)               | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$         |      | 1     | 2          | mA   |
|                        | Supply Current RESET Mode                  | f <sub>OSC</sub> = 8MHz,<br>V <sub>RESET</sub> = V <sub>SS</sub> |      | 1     | 7          | mA   |
|                        | Supply Current STOP Mode <sup>(3)(4)</sup> | $I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$                              |      | 1     | 10         | μΑ   |

Notes :

1. No Watchdog Reset activated.

2. Reset generated by Watchdog.

3. When the watchdog function is activated the STOP instruction is deactivated. WAIT instruction is automatically executed.

4. All on-chipperipherals in OFF state

5. Pull-up resistor



# AC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                           | Test Condition s                                                    |         | Value          |            | Unit   |
|------------------|-------------------------------------|---------------------------------------------------------------------|---------|----------------|------------|--------|
| Symbol           | Farameter                           | rest conditions                                                     | Min.    | Тур.           | Max.       | Onit   |
| fosc             | Oscillator Frequency <sup>(2)</sup> | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01    |                | 8.388<br>2 | MHz    |
| ts∪              | Oscillator Start-up Time            | $C_{L1} = C_{L2} = 22pF - crystal$                                  |         | 5              | 20         |        |
| t <sub>SR</sub>  | Supply Rise Time                    | 10% to 90%                                                          | 0.01    |                | 100        | ms     |
| t <sub>REC</sub> | Supply Recovery Time <sup>(1)</sup> |                                                                     | 100     |                |            |        |
| Tw               | Minimum Pulse Width                 | NMI Pin<br>V <sub>DD</sub> = 5V                                     | 100     |                |            | ns     |
|                  |                                     | RESET Pin                                                           | 100     |                |            | ns     |
| T <sub>WEE</sub> | EEPROM Write Time                   | $T_A = 25^{\circ}C$ One Byte<br>$T_A = 85^{\circ}C$ One Byte        |         | 5<br>15        | 10<br>25   | ms     |
| Endurance        | EEPROM WRITE/ERASE<br>Cycles        | Q <sub>A</sub> Lot<br>Acceptance Criteria                           | 300.000 | > 1<br>million |            | cycles |
| Retention        | EEPROM Data Retention               | T <sub>A</sub> = 55°C                                               | 10      |                |            | years  |
| CIN              | Input Capacitance                   | All Inputs Pins                                                     |         |                | 10         | pF     |
| C <sub>OUT</sub> | Output Capacitance                  | All Outputs Pins                                                    |         |                | 10         | pF     |

Notes:

1. Period for which  $V_{DD}$  has to be connected or at 0V to allow internal Reset function at next power-up.

2. Operation below 0.01 MHz is possible but requires increased supply current.



# I/O PORTS

 $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwise specified})$ 

| Symbol          | Parameter                 | Test Condition s                                        |                      | Value |                      | Unit |
|-----------------|---------------------------|---------------------------------------------------------|----------------------|-------|----------------------|------|
| Symbol          | Farameter                 | Test Condition's                                        | Min.                 | Тур.  | Max.                 | Onit |
| VIL             | Input Low Level Voltage   | I/O Pins                                                |                      |       | 0.3V <sub>DD</sub>   | V    |
| V <sub>IH</sub> | Input High Level Voltage  | I/O Pins                                                | $0.7 V_{DD}$         |       |                      | V    |
|                 |                           | I/O Pins,<br>I <sub>O</sub> = 10μA (sink)               |                      |       | 0.1                  | V    |
|                 | Low Level Output Voltage  | I/O Pins, $I_{OL} = V_{DD}x1mA$<br>$V_{DD} = 4.5$ to 6V |                      |       | 0.16xV <sub>DD</sub> | V    |
|                 |                           | I/O Pins, $I_{OL} = 1.6mA$<br>V <sub>DD</sub> = 3V      |                      |       | 0.4                  | V    |
| V <sub>OL</sub> |                           | I/O Pins, $I_{OL} = V_{DD}x2mA$<br>$V_{DD} = 4.5$ to 6V |                      |       | 0.16xV <sub>DD</sub> | V    |
|                 | Low Level Output Voltage, | I/O Pins, $I_{OL} = 3.2mA$<br>V <sub>DD</sub> = 3V      |                      |       | 0.4                  | V    |
|                 | PB4-PB7 Only              | I/O Pins, $I_{OL} = V_{DD}x4mA$<br>$V_{DD} = 4.5$ to 6V |                      |       | 0.26xV <sub>DD</sub> | V    |
|                 |                           | I/O Pins, $I_{OL} = 6.4mA$<br>$V_{DD} = 3V$             |                      |       | 0.8                  | V    |
| Vон             | High Level Output Voltage | I/O Pins,<br>I <sub>O</sub> = -10μA (source)            | V <sub>DD</sub> -0.1 |       |                      | V    |
| VOH             |                           | I/O Pins, $I_{OL} = -V_{DD}x1mA$<br>$V_{DD} = 5.0V$     | 0.6xV <sub>DD</sub>  |       |                      | V    |
| І⊥<br>Ін        | Input Leakage Current     | I/O Pins, <sup>(1)</sup>                                |                      | 0.1   | 1.0                  | μA   |
| R <sub>PU</sub> | Pull-up Resistor          | I/O Pins $V_{IN} = 0V, V_{DD} = 5.0V$                   | 40                   | 100   | 200                  | kΩ   |

Note 1. Pull-up resistor off

# SPI ELECTRICAL CHARACTERISTICS

(V<sub>DD</sub> = 5.0V,  $T_A$  = -40 to +85°C unless otherwhise specified)

| Symbol          | Parameter       | Test Conditions    | Value |      |      | Unit |
|-----------------|-----------------|--------------------|-------|------|------|------|
| Gymbol          | i didineter     |                    | Min.  | Тур. | Max. | Onic |
| F <sub>CL</sub> | Clock Frequency | applied on PB5/SCL |       |      | 1    | MHz  |
| ts∪             | Set-up Time     | applied on PB6/Sin |       | 50   |      | ns   |
| t <sub>h</sub>  | Hold Time       | applied on PB6/Sin |       | 100  |      | ns   |



# **A/D CONVERTER CHARACTERISTICS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                          | Parameter                                 | Test Conditions                                        |                 | Value |                 | Unit |
|---------------------------------|-------------------------------------------|--------------------------------------------------------|-----------------|-------|-----------------|------|
| Gymbol                          | i didineter                               |                                                        | Min.            | Тур.  | Max.            | onit |
| Res                             | Resolution (3)                            |                                                        |                 | 8     |                 | Bit  |
| A <sub>TOT</sub>                | Total Accuracy (3)                        | f <sub>OSC</sub> > 1.2 MHz<br>f <sub>OSC</sub> > 32kHz |                 |       | ± 2<br>±4       | LSB  |
| tc <sup>(1)</sup>               | Conversion Time                           | f <sub>OSC</sub> = 8MHz                                |                 | 70    |                 | μs   |
| V <sub>AN</sub>                 | Conversion Range                          |                                                        | V <sub>SS</sub> |       | V <sub>DD</sub> | V    |
| ZIR                             | Zero Input Reading                        | Conversion result when $V_{IN} = V_{SS}$               | 00              |       |                 | Hex  |
| FSR                             | Full Scale Reading                        | Conversion result when $V_{IN} = V_{DD}$               |                 |       | FF              | Hex  |
| ADı                             | Analog Input Current During<br>Conversion | V <sub>DD</sub> = 4.5V                                 |                 |       | 1.0             | μΑ   |
| AC <sub>IN</sub> <sup>(2)</sup> | Analog Input Capacitance                  |                                                        |                 | 2     | 5               | pF   |
| ASI                             | Analog Source Impedance                   |                                                        |                 |       | 30              | kΩ   |
| SSI                             | Analog Reference Supply<br>Impedence      |                                                        |                 |       | 2               | kΩ   |

Notes:

1. With oscillator frequencies less than 1MHz, the A/D Converter accuracy is decreased.

2. Excluding Pad Capacitance

3. Noise at  $V_{DD}$ ,  $V_{SS} \le 10 mV$ 



# TIMER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                    | Parameter Test Condition s                                        |                      | Unit |                  |          |
|------------------|------------------------------|-------------------------------------------------------------------|----------------------|------|------------------|----------|
|                  | r didineter                  | Test condition's                                                  | Min.                 | Тур. | Max.             |          |
| t <sub>RES</sub> | Resolution                   |                                                                   | $\frac{12}{f_{OSC}}$ |      |                  | second   |
| f <sub>IN</sub>  | Input Frequency on TIMER Pin |                                                                   |                      |      | <u>fosc</u><br>8 | MHz      |
| tw               | Pulse Width at TIMER Pin     | $\begin{array}{l} V_{DD} \geq 3V \\ V_{DD} \geq 4.5V \end{array}$ | 1<br>125             |      |                  | μs<br>ns |

# LCD ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                        | Test Conditions                              | Value |      |      | Unit |
|------------------|----------------------------------|----------------------------------------------|-------|------|------|------|
| Gymbol           | i didineter                      |                                              |       | Тур. | Max. | onic |
| f <sub>FR</sub>  | Frame Frequency                  | 1/4 Duty<br>f <sub>OSC</sub> = 1, 2, 4, 8MHz | 16    |      | 128  | Hz   |
| V <sub>OS</sub>  | DC Offset Voltage <sup>(1)</sup> | $V_{LCD} = V_{DD}$ , no load                 |       |      | 50   | mV   |
| V <sub>OH</sub>  | COM High Level, Output Voltage   | $I = 100 \mu A V_{LCD} = 5V$                 | 4.5V  |      |      | V    |
| Vol              | COM Low Level, Output Voltage    | $I = 100 \mu A V_{LCD} = 5V$                 |       |      | 0.5V | V    |
| V <sub>OH</sub>  | SEG High Level, Output Voltage   | $I = 50\mu A V_{LCD} = 5V$                   | 4.5V  |      |      | V    |
| V <sub>OL</sub>  | SEG Low Level, Output Voltage    | $I = 50\mu A V_{LCD} = 5V$                   |       |      | 0.5V | V    |
| V <sub>LCD</sub> | Display Voltage                  | Note 2                                       | 3     |      | 10   | V    |

Notes :

1. The DC offset voltage refers to all segment and common outputs. It is the difference between the measured voltage value and nominal value for every voltage level. Ri of voltage meter must be greater than or equal to  $100M\Omega$ .

2. An external resistances network is required when  $V_{\text{LCD}} \leq 4.5 \text{V}.$ 



# PACKAGE MECHANICAL DATA

# Figure 3. ST62E42 64 Pin Ceramic Quad Flat Package with Window





# **ORDERING INFORMATION TABLE**

| Sales Types | Memory type | Temperature Range   | Package  |
|-------------|-------------|---------------------|----------|
| ST62E42G1   | 8K EPROM    | tested at 25°C only | CQFP64-W |
| ST62T42Q6   | 8K EPROM    | -40 to + 85°C       | PQFP64   |





# TRONICSST62458-BIT HCMOS MCU WITH LCD DRIVER,<br/>EEPROM AND A/D CONVERTER

- 3 to 6V supply operating range
- 8.4MHz Maximum Clock Frequency
- -40 to +85°C Operating Temperature Range
- Run, Wait & Stop Modes
- 5 different interrupt vectors
- Look-up table capability in ROM

| User ROM: | 3884 | bytes |
|-----------|------|-------|
| Data RAM: | 128  | bytes |
| LCD RAM:  | 12   | bytes |
| EEPROM:   | 64   | bytes |

- PQFP52 package
- 11 fully software programmable I/O as:
  - Input with/without pull-up resistor
  - Input with interrupt generation
  - Open-Drain or Push-pull outputs
  - Analog Inputs (7 pins)
- 4 I/O lines can sink up to 20mA for direct LED or TRIAC driving, and have SPI alternate functions
- Two 8-bit counters with 7-bit programmable prescalers (Timers 1 and 2)
- Software activated digital watchdog
- 8-bit A/D converter with up to 7 analog inputs
- 8-bit synchronous Serial Peripheral Interface (SPI)
- LCD driver with 24 segment outputs, 4 backplane outputs and selectable duty cycle for up to 96 LCD segments direct driving
- 32kHz oscillator for stand-by LCD operation
- One external not maskable interrupt
- 9 powerful addressing modes
- The accumulator, the X, Y, V & W registers, the port and peripherals data & control registers are addressed in the data space as RAM locations.
- The ST62E45 is the EPROM version, ST62T45 is the OTP version
- Development tool: ST6245-EMU connected via RS232 to an MS-DOS Personal Computer



April 1995

157/232

This is Preliminary Data from SGS-THOMSON, details are subject to change without notice.

# ST6245





# ST6245 Pin Description

| Pin                                       | Pin                                                                              | Pin                                                | Pin                                                                                                                                       | Pin                                                | Pin                                                                         | Pin                                                | Pin                                                         |
|-------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------|----------------------------------------------------|-------------------------------------------------------------|
| number                                    | name                                                                             | number                                             | name                                                                                                                                      | number                                             | name                                                                        | number                                             | name                                                        |
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9 | COM4<br>COM3<br>COM2<br>COM1<br>VLCD1/3<br>VLCD2/3<br>VLCD<br>PA7/Ain<br>PA6/Ain | 14<br>15<br>16<br>17<br>18<br>19<br>20<br>21<br>22 | RESET       OSCout       OSCin       NMI       TIMER       PB7/Sout     (1)       PB6/Sin     (1)       PB5/SCL     (1)       PB4     (1) | 27<br>28<br>29<br>30<br>31<br>32<br>33<br>34<br>35 | OSC32out<br>OSC32in<br>S17<br>S18<br>S19<br>S20<br>S21<br>S22<br>S22<br>S23 | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48 | S28<br>S29<br>S30<br>S31<br>S32<br>S33<br>S34<br>S35<br>S36 |
| 10                                        | PA5/Ain                                                                          | 23                                                 | PB3/Ain                                                                                                                                   | 36                                                 | S24                                                                         | 49                                                 | S37                                                         |
| 11                                        | TEST                                                                             | 24                                                 | PB2/Ain                                                                                                                                   | 37                                                 | S25                                                                         | 50                                                 | S38                                                         |
| 12                                        | V <sub>DD</sub>                                                                  | 25                                                 | PB1/Ain                                                                                                                                   | 38                                                 | S26                                                                         | 51                                                 | S39                                                         |
| 13                                        | V <sub>SS</sub>                                                                  | 26                                                 | PB0/Ain                                                                                                                                   | 39                                                 | S27                                                                         | 52                                                 | S40                                                         |

Note 1: 20mA SINK



# **GENERAL DESCRIPTION**

The ST6245 microcontroller is a member of the 8-bit HCMOS ST62xx family, a series of devices oriented to low-medium complexity applications. All ST62xx members are based on a building block approach: a common core is associated with a combination of on-chip peripherals (macrocells). The macrocells of the ST6245 are: a high performance LCD controller/driver with 24 segment outputs and 4 backplanes able to drive up to 96 segments, two Timer peripherals each including an 8-bit counter with a 7-bit software programmable prescaler (Timer), the digital watchdog (DWD), an 8-bit A/D Converter with up to 7 analog inputs and an 8-bit synchronous Serial Peripheral Interface (SPI). In addition these devices offer 64 bytes of EEPROM for storage of non volatile data. Thanks to these peripherals the ST6245 is well suited for general purpose, automotive, security, appliance and industrial applications. The ST62E45 EPROM version is available for prototypes and low-volume production, an OTP version is also available (see separate datasheet).



#### Figure 2. ST6245 Block Diagram

Note <sup>(1)</sup>: V<sub>PP</sub> only exists in EPROM version



# ST6245

# PIN DESCRIPTION

 $V_{DD}$  and  $V_{SS}.$  Power is supplied to the MCU using these two pins.  $V_{DD}$  is power and Vss is the ground connection.

**OSCin and OSCout**. These pins are internally connected with the on-chip oscillator circuit. A quartz crystal or a ceramic resonator can be connected between these two pins in order to allow the correct operation of the MCU with various stability/cost trade-offs. OSCin is the input pin, OSCout is the output pin. An external clock signal can be applied to OSCin.

**RESET.** The active low **RESET** pin is used to restart the microcontroller at the beginning of its program. The **RESET** pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TEST.** The TEST must be held at  $V_{SS}$  for normal operation (an internal pull-down resistor selects normal operating mode if TEST pin is not connected).

**NMI.** The NMI pin provides the capability for asynchronous applying an external top priority interrupt to the MCU. This pin is falling edge sensitive. The NMI pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TIMER.** This is the TIMER 1 I/O pin. In input mode it is connected to the prescaler and acts as external timer clock or as control gate for the internal timer clock. In the output mode the TIMER pin outputs the data bit when a time-out occurs.

**PA5-PA7.** These 3 lines are organized as one I/O port (A). Each line may be configured under software control as an input with or without pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output or as analog input for the A/D converter. Port A has a 5mA drive capability in output mode.

**PB0-PB3,PB4-PB7.** These 8 lines are organized as one I/O port (B). Each line may be configured under software control as an input with or without internal pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output. PB0-PB3 can be programmed as analog inputs for the A/D converter while PB4-PB7 can also sink 20mA for direct LED driving. PB5-PB7 can also be used as respectively Clock, Data in and Data out pins for the on-chip SPI to carry the synchronous serial I/O signals.

**COM1-COM4.** These four pins are the LCD peripheral common outputs. They are the outputs of the on-chip backplane voltage generator which is used for multiplexing the 24 LCD lines allowing up to 96 segments to be driven.

**S17-S40.** These pins are the 24 LCD peripheral driver outputs of ST6245. Segments S1-S16 and S41-S48 are not connected to any pin.

**VLCD.** Display voltage supply. It determines the high voltage level on COM1-COM4 and S1-S24 pins.

VLCD1/3, VLCD2/3. Display supply voltage inputs for determining the display voltage levels on COM1-COM4 and S1-S24 pins during multiplex operation.

**OSC32in and OSC32out.** These pins are internally connected with the on-chip 32kHz oscillator circuit. A 32.768kHz quartz crystal can be connected between these two pins if it is necessary to provide the LCD stand-by clock and real time interrupt. OSC32in is the input pin, OSC32out is the output pin.



# ST62xx CORE

The core of the ST62xx Family is implemented independently from the I/O or memory configuration. Consequently, it can be treated as an independent central processor communicating with I/O and memory via internal addresses, data, and control busses. The in-core communication is arranged as shown in Figure 3; the controller being externally linked to both the reset and the oscillator, while the core is linked to the dedicated on-chip macrocells peripherals via the serial data bus and indirectly for interrupt purposes through the control registers.

# Registers

The ST62xx Family core has six registers and three pairs of flags available to the programmer. They are shown in Figure 4 and are explained in the following paragraphs.

Accumulator (A). The accumulator is an 8-bit general purpose register used in all arithmetic calculations, logical operations, and data manipulations. The accumulator is addressed in the data space as RAM location at address FFh. Accordingly, the ST62xx instruction set can use the accumulator as any other register of the data space.





# Figure 4. ST62xx Core Programming Model





# ST62xx CORE (Continued)

**Indirect Registers (X, Y).** These two indirect registers are used as pointers to memory locations in the data space. They are used in the register-indirect addressing mode. These registers can be addressed in the data space as RAM locations at addresses 80h (X) and 81h (Y). They can also be accessed with the direct, short direct, or bit direct addressing modes. Accordingly, the ST62xx instruction set can use the indirect registers as any other register of the data space.

**Short Direct Registers (V, W).** These two registers are used to save one byte in short direct addressing mode. These registers can be addressed in the data space as RAM locations at addresses 82h (V) and 83h (W). They can also be accessed with the direct and bit direct addressing modes. Accordingly, the ST62xx instruction set can use the short direct registers as any other register of the data space.

# Program Counter (PC)

The program counter is a 12-bit register that contains the address of the next ROM location to be processed by the core. This ROM location may be an opcode, an operand, or an address of operand. The 12-bit length allows the direct addressing of 4096 bytes in the program space.

The PC value is incremented after it is read from the address of the current instruction. To execute relative jumps the PC and the offset are shifted through the ALU, where they will be added, and the result is shifted back into the PC. The program counter can be changed in the following ways:

| - JP (Jump) instruction | PC=Jump address |
|-------------------------|-----------------|
|-------------------------|-----------------|

| PC=Call address     |
|---------------------|
|                     |
| $PC=PC \pm offset$  |
| PC=Interrupt vector |
|                     |

- Reset . . . . . . . . . PC=Reset vector
- RET & RETI instructions . PC=Pop (stack)
- Normal instruction . . . . PC=PC+1

# Flags (C, Z)

The ST62xx core includes three pairs of flags that correspond to 3 different modes: normal mode, interrupt mode and Non-Maskable Interrupt-Mode. Each pair consists of a CARRY flag and a ZERO flag. One pair (CN, ZN) is used during normal operation, one pair is used during the interrupt mode (CI, ZI) and one is used during the not-maskable interrupt mode (CNMI, ZNMI).

The ST62xx core uses the pair of flags that correspond to the actual mode: as soon as an interrupt (resp. a Non-Maskable-Interrupt) is generated, the ST62xx core uses the interrupt flags (resp. the NMI flags) instead of the normal flags. When the RETI instruction is executed, the normal flags (resp. the interrupt flags) are restored if the MCU was in the normal mode (resp. in the interrupt mode) before the interrupt. It should be observed that each flag set can only be addressed in its own mode (Notmaskable interrupt, normal interrupt or main mode). The flags are not cleared during the context switching and so remain in the state they were at the exit of the last mode switch.

The Carry flag is set when a carry or a borrow occurs during arithmetic operations, otherwise it is cleared. The Carry flag is also set to the value of the bit tested in a bit test instruction, and participates in the rotate left instruction.

The Zero flag is set if the result of the last arithmetic or logical operation was equal to zero, otherwise it is cleared.

The switching between the three sets of Flags is automatically performed when an NMI, an interrupt or a RETI instruction occurs. As the NMI mode is automatically selected after the reset of the MCU, the ST62xx core uses at first the NMI flags.



# ST62xx CORE (Continued)

# Stack

The ST62xx core includes a true LIFO hardware stack that eliminates the need for a stack pointer. The stack consists of six separate 12-bit RAM locations that do not belong to the data space RAM area. When a subroutine call (or interrupt request) occurs, the contents of each level is shifted into the next level while the content of the PC is shifted into the first level (the value of the sixth level will be lost). When a subroutine or interrupt return occurs (RET or RETI instructions), the first level register is shifted back into the PC and the value of each level is popped back into the previous level. These two operating modes are described in Figure 5. Since the accumulator, as all other data space registers, is not stored in the stack, the handling of these registers should be performed inside the subroutine. The stack pointer will remain in its deepest position if more than 6 calls or interrupts are executed, so that the last return address will be lost. It will also remain in its highest position if the stack is empty and a RET or RETI is executed. In this case the next instruction will be executed.

# Figure 5. Stack Operation



# MEMORY SPACES

The MCU operates in three different memory spaces: program space, data space, and stack space. A description of these spaces is shown in the following figures.

# **Program Space**

The program space is physically implemented in the ROM memory and includes all the instructions that are to be executed, as well as the data required for the immediate addressing mode instructions, the reserved test area and the user vectors. It is addressed by the 12-bit Program Counter register (PC register) and so the ST62xx core can directly address up to 4K bytes of Program Space.

# Table 1. ST6245 Program ROM Memory Map

| Device Address                                           | Description                                              |
|----------------------------------------------------------|----------------------------------------------------------|
| 0000h-007Fh<br>0080h-0F9Fh<br>0FA0h-0FEFh<br>0FF0h-0FF7h | Reserved<br>User ROM<br>Reserved<br>Interrupt<br>Vectors |
| 0FF8h-0FFBh<br>0FFCh-0FFDh<br>0FFEh-0FFFh                | Reserved<br>NMI Vector<br>Reset Vector                   |



# Figure 6. ST62xx Memory Addressing Description Diagram





# **Data Space**

The instruction set of the ST62xx core operates on a specific space, named Data Space, that contains all the data necessary for the processing of the program. The Data Space allows the addressing of RAM memory, ST62xx core/peripheral registers, and read-only data such as constants and look-up tables.

**Data ROM.** All the read-only data is physically implemented in the ROM memory in which the Program Space is also implemented. The ROM memory contains consequently the program to be executed, the constants and the look-up tables needed for the program.

The locations of Data Space in which the different constants and look-up tables are addressed by the ST62xx core can be considered as being a 64-byte window through which it is possible to access to the read-only data stored in the ROM memory.

**Data RAM/EEPROM**. The ST6245 offers 128 bytes of data RAM memory and 64 bytes of EEPROM. 64 bytes of RAM are directly addressed in data space in the range 080h-0BFh (static space). The additional RAM are addressed using the banks of 64 bytes located between addresses 00h and 3Fh.

Additionally RAM are available in the LCD data map from E0h to F7h and are not banked.

# Stack Space

The stack space consists of six 12 bit registers that are used for stacking subroutine and interrupt return addresses plus the current program counter register.

|                                                            | 000             |
|------------------------------------------------------------|-----------------|
| DATA RAM/EEPROM BANK AREA                                  |                 |
|                                                            | 03F             |
|                                                            | 040             |
| DATA ROM WINDOW AREA                                       | 076             |
| X REGISTER                                                 | 080             |
| Y REGISTER                                                 | 08              |
| V REGISTER                                                 | 082             |
| W REGISTER                                                 | 083             |
| DATA RAM 60 BYTES                                          | 084             |
|                                                            | 0BF             |
| PORT A DATA REGISTER                                       | 000             |
| PORT B DATAREGISTER                                        | 0C <sup>-</sup> |
| SPI INT. DISABLE REGISTER                                  | 0C2             |
|                                                            | 0C:             |
| PORT A DIRECTION REGISTER                                  | 0C4             |
| PORT B DIRECTION REGISTER                                  | 003             |
| RESERVED                                                   | 000             |
|                                                            | 00              |
|                                                            | 000             |
|                                                            | 009             |
|                                                            | 004             |
|                                                            | 000             |
| PORT A OPTION REGISTER                                     | 000             |
|                                                            | 000             |
| PORT B OPTION REGISTER                                     | 000             |
|                                                            | 000             |
|                                                            | 0D              |
|                                                            | 0D              |
| TIMER 1 PRESCALER REGISTER                                 | 0D:             |
|                                                            | 0D:             |
| TIMER 1 STATUS/CONT REGISTER<br>TIMER 2 PRESCALER REGISTER | 0D4<br>0D5      |
| TIMER 2 COUNTER REGISTER                                   | 0D:             |
| TIMER 2 STATUS/CONT REGISTER                               | 00              |
| WATCHDOG REGISTER                                          | 00              |
| RESERVED                                                   | 000             |
| RESERVED                                                   | 0D              |
| 32kHz OSC. CONTROLREGISTER                                 | 007             |
| LCD MODE CONTROL REGISTER                                  | 000             |
| SPI DATA REGISTER                                          | 001             |
| RESERVED                                                   |                 |
| EEPROM CONTROL REGISTER                                    | 001             |
|                                                            | 0D              |
| LCD RAM                                                    | 0E0             |
|                                                            | 0F8             |
| DATA RAM 7 BYTES                                           | 0F8             |
| ACCUMULATOR                                                | 0FE             |

# Figure 7. ST6240 Data Memory Space





# Data Window register (DWR)

The Data ROM window is located from address 040h to address 7Fh in the Data space. It allows the direct reading of 64 consecutive bytes located anywhere in the ROM memory between the addresses 0000h and 1FFFh. All the bytes of the ROM memory can be used to store either instructions or read-only data. Indeed, the window can be moved by step of 64 bytes along the ROM memory in writing the appropriate code in the Write-only Data Window register (DWR register, location C9h).

The DWR register can be addressed like a RAM location in the Data Space at the address C9h, nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to move the 64-byte read-only data window (from the 40h address to 7Fh address of the Data Space) up and down the ROM memory of the MCU in steps of 64 bytes. The effective address of the byte to be read as a data in the ROM memory is obtained by the concatenation of the 6 least significant bits of the register address given in the instruction (as least significant bits) and the content of the DWR register (as most significant bits, see Figure 8). So when addressing location 40h of dataspace, and 0 is loaded in the DWR register, the phisycal addressed location in ROM is 00h. The DWR register is not cleared at reset, therefore it must be written to before the first access to the Data ROM window area.



# Figure 9. Data ROM Window Register

**D7.** This bit is not used.

**DWR6-DWR0.** These are the Data ROM Window bits that correspond to the upper bits of the data ROM space.

#### This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

**Note:** Care is required when handling the DWR register as it is write only. For this reason, it is not allowed to change the DWR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. If it is impossible to avoid the writing of this register in the interrupt service routine, an image of this register must be saved in a RAM location, and each time the program writes to the DWR it must write also to the image register. The image register must be written first, so if an interrupt occurs between the two instructions the DWR is not affected.





# Data RAM/EEPROM Bank Register (DRBR)

The selection of the bank is made by programming the Data RAM Bank Switch register (DRBR register) located at address CBh of the Data Space. The number of the selected bank is equal to the bit content of the DRBR register. In this way each bank of RAM or EEPROM can be selected 64 bytes at a time. No more than one bank should be set at a time.

The DRBR register can be addressed like a RAM location in the Data Space at the address CBh; nevertheless it is a write only register that cannot be accessed with single-bit operations. This register is used to select the desired 64-byte RAM/EEPROM bank of the Data Space. The number of the bank has to be loaded in the DRBR register and the instruction has to point to the selected location as if it was in bank 0 (from 00h address to 3Fh address). This register is not cleared during the MCU initialization, therefore it must be written before the first access to the Data Space bank region. Refer to the Data Space description for additional information. The DRBR register is not modified when a interrupt or a subroutine occurs.

#### Table 2. Data RAM Bank Register Set-up

| DRBR Value | Selection |
|------------|-----------|
| 01h        | EEPROM    |
| 10h        | RAM       |



Figure 10. Data RAM Bank Register

The following Table 2 summarizes how to set the data RAM bank register in order to select the various banks or pages.

**D7-D5.** These bits are not used.

DRBR3. This bit, when set, will select RAM page.

**D3-D1.** These bits are not used.

**DRBR0.** This bit, when set, will select EEPROM page.

This register is undefined on reset. Neither read nor single bit instructions may be used to address this register.

# Notes:

Care is required when handling the DRBR register as it is write only. For this reason, it is not allowed to change the DRBR contents while executing interrupt service routine, as the service routine cannot save and then restore its previous content. If it is impossible to avoid the writing of this register in interrupt service routine, an image of this register must be saved in a RAM location, and each time the program writes to DRBR it must write also to the image register. The image register must be written first, so if an interrupt occurs between the two instructions the DRBR is not affected.

In DRBR Register, *only 1 bit must be set.* Otherwise two or more pages are enabled in parallel, producing errors.



# **EEPROM Description**

The data space of ST62xx family from 00h to 3Fh is paged as described in Table 3. The ST6245 has 64 bytes of EEPROM located in one page of 64 bytes (page 0).

The EEPROM pages are physically organized in 32 byte modules (2 modules per page) and does not require dedicated instructions to be accessed in reading or writing. The EEPROM is controlled by the EEPROM Control Register (EECTL = DFh). In order to enable access to the EEPROM, bit 6 of this register must be cleared otherwise any access to the EEPROM will be meaningless.

Any EEPROM location can be read just like any other data location, also in terms of access time.

When writing to an EEPROM, the EEPROM is not accessible by the ST62xx. A busy flag can be read to identify the EEPROM status before attempting any access. Writing the EEPROM can work in two modes: Byte Mode (BMODE) and Parallel Mode (PMODE). BMODE is the normal way to use the EEPROM and consists in accessing one byte at a time. PMODE consists in accessing 8 bytes per time.

Readout of the EEPROM is made at the same speed as RAM acces.



# D7. Not Used

**E2OFF.** *WRITE ONLY*. If this bit is set the EEPROM is disabled (any access will be meaningless) and the power consumption of the EEPROM is reduced to the lowest values.

D5, D4. Reserved, must be set to zero.

**E2PAR1.** *WRITE ONLY.* Once in Parallel Mode, as soon as the user software sets the E2PAR1 bit the parallel writing of the 8 adjacent registers will start. It is internally reset at the end of the programming procedure. Note that less than 8 bytes can be written; after parallel programming the undefined bytes will be unaffected

**E2PAR2.** *WRITE ONLY.* This bit must be set by the user program in order to perform parallel programming (more than one byte at a time). If E2PAR2 is set and the parallel start bit (E2PAR1) is low, up to 8 adjacent bytes can be written at maximum speed, the contents being stored in volatile registers. These 8 adjacent bytes are considered as a row, whose address lines A7, A6, A5, A4, A3 are fixed while A2, A1 and A0 are the changing bits. E2PAR2 is automatically reset at the end of any parallel programming procedure. It can be reset by the user software before starting the programming procedure, leaving the EEPROM registers unchanged.

**E2BUSY.** *READ ONLY.* This bit will be automatically set by the EEPROM control logic when the user program modifies an EEPROM register. The user program must test it before any read or write EEPROM operation; any attempt to access the EEPROM while the busy bit is set will be aborted and the writing procedure in progress completed.

**E2ENA.** WRITE ONLY. This bit MUST be set to one in order to write to any EEPROM register. If the user program attempts to write to the EEPROM when E2ENA = "0", the involved registers will be unaffected and the BS will not be set.

After RESET the content of EECTL register will be 00h.

# Notes:

The data to write has to be written directly at the address that it will have inside the EEPROM space. There is no buffer memory between the data•RAM and the EEPROM spaces.

When the EEPROM is busy (E2BUSY = "1") EECTL can not be accessed in write mode, it is only possible to read the status of E2BUSY. This implies that as long as the EEPROM is busy, it is not possible to change the status of the EEPROM control register. EECTL bits 4 and 5 are reserved for test purposes, and must never be set to "1".





Table 3. EEPROM Parallel Write Row Structure



Additional Notes on Parallel Mode. If the user wishes to perform parallel programming, the first action should be to set the E2PAR2 bit to one. From this time the EEPROM will be addressed in writing, the ROW address will be latched and it will be possible to change it only at the end of the programming procedure or by resetting E2PAR2 without programming the EEPROM. After the ROW address latching the ST62xx can "see" only one EEPROM row (the selected one) and any attempt to write or read other rows will produce errors. Do not read the EEPROM while E2PAR2 is set.

As soon as E2PAR2 bit is set, the 8 volatile ROW latches are cleared. From this moment the user can load data in the whole ROW or in a subset. Setting E2PAR1 will modify the EEPROM registers corre-

sponding to the ROW latches accessed after E2PAR2. For example, if the software sets E2PAR2 and accesses the EEPROM by writing to addresses 18h, 1Ah, 1Bh and then sets E2PAR1, these three registers will be modified at the same time; the remaining bytes will be unaffected. Note that E2PAR2 is internally reset at the end of the programming procedure. This implies that the user must set E2PAR2 bit between two parallel programming procedures. Note that if the user tries to set E2PAR1 while E2PAR2 is not set there will not be any programming procedure and the E2PAR1 bit will be unaffected. Consequently E2PAR1 bit cannot be set if E2ENA is low. E2PAR1 can be affected by the user to set it, only if E2ENA and E2PAR2 bits are also set to one.



# **TEST MODE**

For normal operation the TEST pin must be held low. An on-chip  $100k\Omega$  pull-down resistor is internally connected to the TEST pin.

# **INTERRUPTS**

The ST62xx core can manage 4 different maskable interrupt sources, plus one non-maskable interrupt source (top priority level interrupt). Each source is associated with a particular interrupt vector that contains a Jump instruction to the related interrupt service routine. Each vector is located in the Program Space at a particular address.

When a source provides an interrupt request, and the request processing is also enabled by the ST62xx core, then the PC register is loaded with the address of the interrupt vector (i.e. of the Jump instruction). Finally, the PC is loaded with the address of the Jump instruction and the interrupt routine is processed.

The ST6245 microcontroller has eight different interrupt sources associated to different interrupt vectors as described in Table 4.

| Interrupt<br>Source                 | Associated Vector   | Vector<br>Address |
|-------------------------------------|---------------------|-------------------|
| NMI Pin                             | Interrupt Vector #0 | (FFCh-FFDh)       |
| SPI<br>Peripheral                   | Interrupt Vector #1 | (FF6h-FF7h)       |
| Port A& B<br>Pins                   | Interrupt Vector #2 | (FF4h-FF5h)       |
| TIMER 1, 2<br>& 32kHz<br>Oscillator | Interrupt Vector #3 | (FF2h-FF3h)       |
| ADC<br>Peripheral                   | Interrupt Vector #4 | (FF0h-FF1h)       |

#### Table 4. Interrupt Vectors - Sources Relationship

# **Interrupt Vectors Description**

The ST62xx core includes 5 different interrupt vectors in order to branch to 5 different interrupt routines in the static page of the Program Space:

 The interrupt vector associated with the nonmaskable interrupt source is named interrupt vector #0. It is located at addresses FFCh,FFDh in the Program Space. On ST6245 this vector is associated with the external falling edge sensitive interrupt pin (NMI). An on-chip 100k $\Omega$  pull-up resistor is internally connected to the NMI pin.

- The interrupt vector located at the addresses FF6h, FF7h is named interrupt vector #1. It is associated with SPI peripheral and can be programmed by software to generate an interrupt request after the falling edge or low level of the eighth external clock pulse according to the code loaded in the Interrupt Option Register (IOR).
- The interrupt vector located at the addresses FF4h, FF5h is named interrupt vector #2. It is associated with Port A and B pins and can be programmed by software either in the falling edge detection mode or in the rising edge detection mode according to the code loaded in the Interrupt Option Register (IOR).
- The interrupt vector located at the addresses FF2h, FF3h is named interrupt vector #3. It is associated with Timer 1, Timer 2 and the 32kHz Oscillator peripherals. All these interrupts are "ORed" together and are connected to interrupt line #3 of the core. Discrimination among the three interrupts must be made by polling the Status/Controlregisters of Timer 1 (0D4h), Timer 2 (0D7h) and 32kHz oscillator (0DBh).
- The interrupt vector located at the addresses FF0h, FF1h is named interrupt vector #4. It is associated with the A/D converter peripheral.

All the on-chip peripherals (refer to their descriptions for further details) have an interrupt request flag bit (TMZ for timer, EOC for A/D, etc.), this bit is set to one when the device wants to generate an interrupt request and a mask bit (ETI for timer, EAI for A/D, etc.) that must be set to one to allow the transfer of the flag bit to the Core.

# **Interrupt Priority**

The non-maskable interrupt request has the highest priority and can interrupt any other interrupt routines at any time, nevertheless the four other interrupts cannot interrupt each other. If more than one interrupt request is pending, they are processed by the ST62xx core according to their priority level: vector #1 has the higher priority while vector #4 the lower. The priority of each interrupt source is fixed.



# **INTERRUPTS** (Continued)

#### Interrupt Option Register

The Interrupt Option Register (IOR register, location C8h) is used to enable/disable the individual interrupt sources and to select the operating mode of the external interrupt inputs. This register can be addressed in the Data Space as RAM location at the address C8h, nevertheless it is a write-only register that cannot be accessed with single-bit operations. The operating modes of the external interrupt inputs associated to interrupt vectors #1 and #2 are selected through bits 5 and 6 of the IOR register.

# Figure 12. Interrupt Option Register



**D7.** This bit is not used.

**LES.** Level/Edge Selection Bit. When this bit is set to one, the interrupt #1 (SPI) is low level sensitive, when cleared to zero the negative edge sensitive interrupt is selected.

**ESB.** Edge Selection Bit. When this bit is set to one, the interrupt #2 (Port A & B lines) is positive edge sensitive, when cleared to zero the negative edge sensitive interrupt is selected.

**GEN.** Global Enable Interrupt. When this bit is set to one, all the interrupts are enabled. When this bit is cleared to zero all the interrupts (but NMI) are disabled.

This register is cleared on reset.

| GEN    | SET      | Enable all interrupts                      |
|--------|----------|--------------------------------------------|
| GEN    | CLEARED  | Disable all interrupts                     |
| ESB    | SET      | Rising edge mode on<br>interrupt input #2  |
|        | CLEARED  | Falling edge mode on<br>interrupt input #2 |
| LES    | SET      | Level-sensitive mode on interrupt input #1 |
|        | CLEARED  | Falling edge mode on<br>interrupt input #1 |
| OTHERS | NOT USED |                                            |

#### Table 5. Interrupt Option Register Description

# **External Interrupts Operating Modes**

The NMI interrupt is associated to the NMI pin of the ST6245. The highest priority interrupt request will be generated by a falling edge applied to the NMI pin. The NMI interrupt pin signal is latched and is automatically reset by the core at the beginning of the non-maskable interrupt service routine. An on-chip pull-up resistor and a schmitt trigger is available with the NMI pin.

The two interrupt sources associated with the falling/rising edge mode of the external interrupt pins (SPI vector #1, Ports A and B vector #2,) are connected to two internal latches. Each latch is set when a falling/rising edge occurs and is cleared when the associated interrupt routine is started. So, the occurrence of an external interrupt request is stored: a second interrupt, that occurs during the processing of the first one, will be processed as soon as the first one has been finished (if there is not an higher priority interrupt request). If more than one interrupt occurs during the processing of the first one, these other interrupt requests will be lost.

The storage of the interrupt requests is not available in the level sensitive detection mode. To be taken into account, the low level must be present on the interrupt pin when the core samples the line after the execution of the instructions.

During the end of each instruction the core tests the interrupt lines and if there is an interrupt request the nextinstruction is not executed and the related interrupt routine is executed.



# **INTERRUPTS** (Continued)

Interrupt Procedure. The interrupt procedure is very similar to a call procedure, indeed the user can consider the interrupt as an asynchronous call procedure. As this is an asynchronous event the user does not know about the context and the time at which it occurred. As a result the user should save all the data space registers which will be used inside the interrupt routines. There are separate sets of processor flags for normal, interrupt and non-maskable interrupt modes which are automatically switched and so these do not need to be saved.

The following list summarizes the interrupt procedure:

# ST62xx actions

- Interrupt detection
- The flags C and Z of the main routine are exchanged with the flags C and Z of the interrupt routine (or the NMI flags)
- The value of the PC is stored in the first level of the stack
- The normal interrupt lines are inhibited (NMI still active)
- First internal latch is cleared
- The related interrupt vector is loaded in the PC.
   User actions
- User selected registers are saved inside the interrupt service routine (normally on a software stack)
- The source of the interrupt is found by polling (if more than one source is associated to the same vector) the interrupt flag of the source.
- Interrupt servicing
- Return from interrupt (RETI)
- ST62xx actions
- Automatically the ST62xx core switches back to the normal flags (or the interrupt flags) and pops the previous PC value from the stack

The interrupt routine begins usually by the identification of the device that has generated the interrupt request (by polling). The user should save the registers which are used inside the interrupt routine (that holds relevant data) into a software stack. After the RETI instruction execution, the core carries out the previous actions and the main routine can continue.

# Figure 13. Interrupt Processing Flow-Chart



**WARNING.** GEN is the global enable for all interrupts except NMI. If this bit is cleared, the NMI interrupt is accepted when the ST62xx core is in the normal RUN Mode.

If the ST62xx core is in STOP or WAIT Mode, the NMI is not accepted as a restart is disabled. This state can only be finished by a reset (from the Watchdog or an external Reset Signal).

As a consequence the NMI can be masked in STOP and WAIT modes, but not in RUN mode.



# **INTERRUPTS** (Continued)

# Interrupt request and mask bits

# Interrupt Option Register, IOR Location C8h

- GEN. If this bit is set, all the ST62xx interrupts are enabled, if reset all interrupts are disabled (including the NMI).
- ESB. If this bit is set, all the input lines associated to interrupt vector #2 are rising edge sensitive, if reset they are falling edge sensitive.
- LES. If this bit is set, all the inputs lines associated to interrupt vector #1 are low level sensitive, if reset they are falling edge sensitive.

All other bits in this register are not used.

# Timer Peripherals, TSCR1 and TSCR2 registers, locations D4h and D7h

- TMZ. A low-to-high transition indicates that the timer count register has decremented to zero. This means that an interrupt request can be generated in relation to the state of ETI bit.
- ETI. This bit, when set, enables the timer interrupt request.

# A/D Converter Peripheral, ADCR register location D0h

- EOC. This read only bit indicates when a conversion has been completed, by going to one. An interrupt request can be generated in relation to the state of EAI bit.
- EAI. This bit, when set, enables the A/D converter interrupt request.

#### 32kHz Oscillator, 320CR register location DBh

- EOSCI. This bit, when set, enables the 32kHz oscillator interrupt request.
- OSCEOC. This read only bit indicates when the 32kHz oscillator has measured a 500ms elapsed time (providing a 32.768kHz quartz crystal is connected to the 32kHz oscillator dedicated pins). An interrupt request can be generated in relation to the state of EOSCI bit.



# ST6245

# **INTERRUPTS** (Continued)

# Figure 14. ST6245 Interrupt Circuit Diagram





# RESET

The ST6245 can be reset in three ways: by the external reset input (RESET) tied low, by power-on reset and by the digital watchdog/timer peripheral.

# **RESET Input**

The RESET pin can be connected to a device of the application board in order to restart the MCU during its operation. The activation of the RESET pin may occur in the RUN, WAIT or STOP mode. This input has to be used to reset the MCU internal state and provide a correct start-up procedure. The pin is active low. The internal reset signal is generated by adding a delay to the external signal. Therefore even short pulses at the RESET pin will be accepted. This feature is valid providing that  $V_{DD}$ has finished its rising phase and the oscillator is correctly running (normal RUN or WAIT modes).

If RESET activation occurs in the RUN or Wait mode, the MCU is configured in the Reset mode for as long as the signal of the RESET pin is low. The processing of the program is stopped (in RUN mode only) and the Input/Outputs are in the Highimpedance state with pull-up resistors switched on. As soon as the level on the RESET pin becomes high, the initialization sequence is executed.

If a RESET pin activation occurs in the STOP mode, the oscillator starts and all the inputs/outputs are configured in the High-impedance state with pull-up resistors switched on for as long as the level on the RESET pin remains low. When the level of the RESET pin becomes high, a delay is generated by the ST62xx core to wait that the oscillator becomes completely stabilized. Then, the initialization sequence is started.

# Power-On Reset (POR)

The function of the POR consists in waking up the MCU during the power-on sequence. At the beginning of this sequence, the MCU is configured in the Reset state: every Input/Output port is configured in the input mode (High-impedance state with pull-up) and no instruction is executed. When the power supply voltage becomes sufficient, the oscillator starts to operate, nevertheless the ST62xx core generates a delay to allow the oscillator to be completely stabilized before the execution of the first instruction. The initialization sequence is then executed.

Internal circuitry generates a Reset pulse when V\_DD is switched on. In the case of fast rising V\_DD (transition time  $\leq 100\mu$ s), this reset pulse starts the internal reset procedure without the need of external components at the RESET pin. In cases of slowly or non monotonously rising V\_DD, an external reset signal must be provided for a proper reset of the MCU.

For as long as the reset pin is kept at the low level, the processor remains in the reset state. The reset will be released after the voltage at the reset pin reaches the high level.

# Note:

To have a correct ST62xx start-up, the user should take care that the reset input does not change to the high level before the  $V_{DD}$  level is sufficient to allow MCU operation at the chosen frequency (see recommended operating conditions).

An on-chip counter circuit provides a delay of 2048 oscillator cycles between the detection of the reset high level and the release of the MCU reset.

A proper reset signal for slow rising  $V_{DD}$ , i.e. the required delay between reaching sufficient operating voltage and the reset input changing to a high level, can be generally provided by an external capacitor connected between the RESET pin and  $V_{SS}$ .



# **RESET** (Continued)

# Watchdog Reset

The ST6245 provides an on-chip watchdog function in order to provide a graceful recovery from a software upset. If the watchdog register is not refreshed, preventing the end-of-count being reached, an internal circuit pulls down the RESET pin. The MCU will enter the reset state as soon as the voltage at RESET pin reaches the related low level. This also resets the watchdog which subsequently turns off the pull-down and activates the pull-up device at the RESET pin. This causes the positive transition at the RESET pin and terminates the reset state.

# Figure 15. Reset Circuit



# **Application Notes**

An external resistor between V<sub>DD</sub> and reset pin is not required because an internal pull-up device is provided. If the user prefers, for any reason, to add an external pull-up resistor its value must comply with the Rmin value defined in Figure 16. If the value is lower than Rmin, the on-chip watchdog pull-down transistor might not be able to pull-down the reset pin resulting in an external deactivation of the watchdog function.

The POR function operates in a dynamic manner in the way that it brings about the initialization of the MCU when it detects a dynamic rising edge of the V<sub>DD</sub> voltage. The typical detected threshold is about 2 volts, but the actual value of the detected threshold depends on the way in which the V<sub>DD</sub> voltage rises up. The POR device DOES NOT allow the supervision of a static rising or falling edge of the V<sub>DD</sub> voltage.

# Figure 16. External Reset Resistance





# **RESET** (Continued)

# Figure 17. Reset & Interrupt Processing Flow-Chart



# MCU Initialization Sequence

When a reset occurs the stack is reset to the program counter, the PC is loaded with the address of the reset vector (located in the program ROM at addresses FFEh & FFFh). A jump instruction to the beginning of the program has to be written into these locations. After a reset the interrupt mask is automatically activated so that the core is in non-maskable interrupt mode to prevent false or ghost interrupts during the restart phase. Therefore the restart routine should be terminated by a RETI instruction to switch to normal mode and enable interrupts. If no pending interrupt is present at the end of the reset routine the ST62xx will continue with the instruction after the RETI; otherwise the pending interrupt will be serviced.

# Figure 18. Restart Initialization Program Flow-Chart



# Table 6. Reset Configuration

| Input/Outpu t pins                       | Registers                                                                                                                                                                                            |
|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input Mode with pull-up and no interrupt | All cleared but A,X,Y,V,W,data RAM, LCD RAM,<br>DWR (C9), PRPR (CA), DRBR (CB).<br>Timers prescaler and TCR are initialized respectively at<br>7F and FF. Watchdog register DWDR (D8) is set to FEh. |



# WAIT & STOP MODES

The WAIT and STOP modes have been implemented in the ST62xx core in order to reduce the consumption of the product when the latter has no instruction to execute. These two modes are described in the following paragraphs

# WAIT Mode

The configuration of the MCU in the WAIT mode occurs as soon as the WAIT instruction is executed. The microcontroller can also be considered as being in a "software frozen" state where the core stops processing the instructions of the routine, the contents of the RAM locations and peripheral registers are saved as long as the power supply voltage is higher than the RAM retention voltage but where the peripherals are still working.

The WAIT mode is used when the user wants to reduce the consumption of the MCU when it is in idle, while not losing count of time or monitoring of external events. The oscillator is not stopped in order to provide a clock signal to the peripherals. The timer counting may be enabled (writing the PSI bit in TSCR register) and the timer interrupt may be also enabled before entering the WAIT mode; this allows the WAIT mode to be left when timer interrupt occurs. The above explanation related to the timers applies also to the A/D converter.

If the exit from the WAIT mode is performed with a general RESET (either from the activation of the external pin or by watchdog reset) the MCU will enter a normal reset procedure as described in the RESET chapter. If an interrupt is generated during WAIT mode the MCU behavior depends on the state of the ST62xx core before the initialization of the WAIT sequence, but also of the kind of the interrupt request that is generated. This case will be described in the following paragraphs. In any case, the ST62xx core does not generate any delay after the occurrence of the interrupt because the oscillator clock is still available.

# **STOP Mode**

If the Watchdog is disabled the STOP mode is available. When in STOP mode the MCU is placed in the lowest power consumption mode. In this operating mode the microcontroller can be considered as being "frozen", no instruction is executed, the oscillator is stopped, the contents of the RAM locations and peripheral registers are saved as long as the power supply voltage is higher than the RAM retention voltage, and the ST62xx core waits for the occurrence of an external interrupt request or Reset activation to output from the STOP state.

If the exit from the STOP mode is performed with a general RESET (by the activation of the external pin) the MCU will enter a normal reset procedure as described in the RESET chapter. The case of an interrupt depends on the state of the ST62xx core before the initialization of the STOP sequence and also of the kind of the interrupt request that is generated.

This case will be described in the following paragraphs. In any case, the ST62xx core generates a delay after the occurrence of the interrupt request in order to wait the complete stabilization of the oscillator before the execution of the first instruction.

# **Exit from WAIT and STOP Modes**

The following paragraphs describe the output procedure of the ST62xx core from WAIT and STOP modes when an interrupt occurs (not a RESET). It must be noted that the restart sequence depends on the original state of the MCU (normal, interrupt or non-maskable interrupt mode) before the start of the WAIT or STOP sequence, but also of the type of the interrupt request that is generated.

**Normal Mode.** If the ST62xx core was in the main routine when the WAIT or STOP instruction has been executed, the ST62xx core outputs from the stop or wait mode as soon as any interrupt occurs; the related interrupt routine is executed and at the end of the interrupt service routine the instruction that follows the STOP or the WAIT instruction is executed if no other interrupts are pending.

# WAIT & STOP MODES (Continued)

Not Maskable Interrupt Mode. If the STOP or WAIT instruction has been executed during the execution of the non-maskable interrupt routine, the ST62xx core outputs from the stop or wait mode as soon as any interrupt occurs: the instruction that follows the STOP or the WAIT instruction is executed and the ST62xx core is still in the non-maskable interrupt mode even if another interrupt has been generated.

**Normal Interrupt Mode.** If the ST62xx core was in the interrupt mode before the initialization of the STOP or WAIT sequence, it outputs from the stop or wait mode as soon as any interrupt occurs. Nevertheless, two cases have to be considered:

- If the interrupt is a normal interrupt, the interrupt routine in which the WAIT or STOP was entered will be completed with the execution of the instruction that follows the STOP or the WAIT and the ST62xx core is still in the interrupt mode. At the end of this routine pending interrupts will be serviced in accordance to their priority.
- If the interrupt is a non-maskable interrupt, the non-maskable routine is processed at first. Then the routine in which the WAIT or STOP was entered will be completed with the execution of the instruction that follows the STOP or the WAIT and the ST62xx core remains in the normal interrupt mode.

#### Notes :

To reach the lowest power consumption the user software must take care of:

- placing the A/D converter in its power down mode by clearing the PDS bit in the A/D control register before entering the STOP instruction.
- switching off the 32kHz oscillator by clearing the oscillator start/stop bit in the 32kHz oscillator control register.
- putting the EEPROM on-chip memory in standby mode by setting the E2OFF bit in EEPROM Control Register to one.

The LCD Driver peripheral is automatically switched-off by the STOP instruction when the 32kHz oscillator operation is not selected.

When the hardware activated watchdog is selected or the software watchdog enabled, the STOP instruction is deactivated and any attempt to execute the STOP instruction will cause an execution of a WAIT instruction.

If all the interrupt sources are disabled (including NMI if GEN="0"), the restart of the MCU can only be done by a RESET activation. The WAIT and STOP instructions are not executed if an enabled interrupt request is pending.

# **ON-CHIP CLOCK OSCILLATOR**

The internal oscillator circuit is designed to require a minimum of external components. A crystal, a ceramic resonator, or an external signal (provided to the OSCin pin) may be used to generate a system clock with various stability/cost tradeoffs. The different clock generator options connection methods are shown in Figure 20.

One machine cycle takes 13 oscillator pulses; 12 clock pulses are needed to increment the PC while and additional 13th pulse is needed to stabilize the internal latches during memory addressing. This means that with a clock frequency of 8MHz the machine cycle is 1.625µs.

The crystal oscillator start-up time is a function of many variables: crystal parameters (especially Rs), oscillator load capacitance (CL), IC parameters, ambient temperature, supply voltage. It must be observed that the crystal or ceramic leads and circuit connections must be as short as possible. Typical values for CL1, CL2 are 15-22pF for a 4/8MHz crystal. The oscillator output frequency is internally divided by 13 to produce the machine cycle and by 12 to produce the Timer, the Watchdog and the A/D peripheral clock. Amachine cycle is the smallest unit needed to execute any operation (i.e., increment the program counter). An instruction may need two, four, or five machine cycles to be executed.

#### **Figure 19. Crystal Parameters**





# **ON-CHIP CLOCK OSCILLATOR** (Continued)

# Figure 20. Oscillator Connection





## **INPUT/OUTPUT PORTS**

The ST6245 microcontroller has 11 Input/Output lines that can be individually programmed either in the input mode or the output mode with the following options that can be selected by software:

- Input without pull-up and without interrupt
- Input with pull-up and with interrupt
- Input with pull-up without interrupt
- Analog inputs (PA5-PA7, PB0-PB3)
- SPI control signals (PB5-PB7)
- Push-pull output
- Standard Open drain output
- 20mA Open drain output (PB4-PB7)

The lines are organized in two ports (port A,B).

Each port occupies 3 registers in the data space. Each bit of these registers is associated with a particular line (for instance, the bits 0 of the Port A Data, Direction and Option registers are associated with the PA0 line of Port A).

The two DATA registers (DRA, DRB), are used to read the voltage level values of the lines programmed in the input mode, or to write the logic value of the signal to be output on the lines configured in the output mode. The port data registers can be read to get the effective logic levels of the pins, but they can be also written by the user software, in conjunction with the related option registers, to select the different input mode options.

Single-bit operations on I/O registers are possible but care is necessary because reading in input mode is done from I/O pins while writing will directly affect the Port data register causing an undesired change of the input configuration.

The two Data Direction registers (DDRA, DDRB) allow the selection of the data direction of each pin (input or output).

The two Option registers (ORPA, ORPB) are used to select the different port options available both in input and in output mode.

All the I/O registers can be read or written as any other RAM location of the data space, so no extra RAM cell is needed for port data storing and manipulation. During the initialization of the MCU, all the I/O registers are cleared and the input mode with pull-up/no-interrupt is selected on all the pins, thus avoiding pin conflicts.



## Figure 21. I/O Port Block Diagram



## INPUT/OUTPUT PORTS (Continued)

#### **I/O Pin Programming**

Each pin can be individually programmed as input or output with different input and output configurations.

This is achieved by writing to the relevant bit in the data (DR), data direction register (DDR) and option registers (OR). Table 7 shows all the port configurations that can be selected by user software.

#### **Input Option Description**

**Pull-up, High Impedance Option.** All the input lines can be individually programmed with or without an internal pull-up according to the codes programmed in the OR and DR registers. If the pull-up option is not selected, the input pin is in the high-impedance state.

**Interrupt Option.** All the input lines can be individually connected by software to the interrupt lines of the ST62xx core according to the codes programmed in the OR and DR registers. The pins of Port A and B are "ORed" and are connected to the interrupt associated to the vector #2. The interrupt modes (falling edge sensitive, rising edge sensitive) can be selected by software for each port by programming the IOR register.

**Analog Input Option.** The seven PA5-PA7, PB0-PB3 pins can be configured to be analog inputs according to the codes programmed in the OR and DR registers. These analog inputs are connected to the on-chip 8-bit Analog to Digital Converter. *ONLY ONE* pin should be programmed as analog input at a time, otherwise the selected inputs will be shorted.

#### Figure 22. I/O Port Data Registers







Figure 24. I/O Port Option Registers



**Note:** For complete coding explanation refer to Table 7.



## **INPUT/OUTPUT PORTS** (Continued)

## Table 7. I/O Port Configuration

| DDR,<br>OR | DR | Mod<br>e | Option | Schematic                                                          |          |
|------------|----|----------|--------|--------------------------------------------------------------------|----------|
| 0          | 0  | 0        | Input  | Pull-up<br>No interrupt<br>(RESET state)                           | Data in  |
| 0          | 0  | 1        | Input  | No pull-up<br>No interrupt                                         | Data in  |
| 0          | 1  | 0        | Input  | Pull-up<br>Interrupt                                               | Data in  |
| 0          | 1  | 1        | Input  | No pull-up<br>No interrupt<br>PB4-PB7                              | Data in  |
|            |    |          | Input  | Analog input:<br>PA0-PA7<br>PB2-PB3                                | ADC      |
| 1          | 0  | х        | Output | Open drain: 20mA<br>PB4-PB7<br>Open drain: 5mA<br>PB2-PB3, PA5-PA7 | Data out |
| 1          | 1  | x        | Output | Push-pull                                                          | Data out |



#### INPUT/OUTPUT PORTS (Continued)

**SPI alternate function Option.** The I/O pins PB5-PB7 are also used by serial peripheral interface SPI. PB5 is connected with the SPI clock input SCL, PB6 is connected with the SPI data input SIN and PB7 is connected with the SPI data output SOUT.

For serial input operation PB5 and PB6 have to be programmed as inputs. For serial output operation PB7 has to be programmed as open-drain output (DDR = "1", OPR = "0"). In this operating mode the output of the SPI shift register instead of the port data register is connected to the port buffer. When PB7 is programmed as push-pull output (DDR = "1", OPR = "1"), the port data register is connected to the port buffer. When the SPI peripheral is not used PB5-PB7 can be used as general purpose I/O lines (provided that PB7 is not selected to be open-drain in output mode).

#### Notes:

Switching the I/O ports from one state to another should be done in a way that no unwanted side effects can happen. The recommended safe transitions are shown below. All other transitions are risky and should be avoided during change of operation mode as it is most likely that there will be an unwanted side-effect such as interrupt generation or two pins shorted together by the analog input lines.

Single bit SET and RES instructions should be used very carefully with Port A and B data registers because these instructions make an implicit read and write back of the whole addressed register byte. In port input mode however data register address reads from input pins, not from data register latches and data register information in input mode is used to set characteristics of the input pin (interrupt, pull-up, analog input), therefore these characteristics may be unintentionally reprogrammed depending on the state of input pins. As general rule is better to use SET and RES instructions on data register only when the whole port is in output mode. If input or mixed configuration is needed it is recommended to keep a copy of the data register in RAM. On this copy it is possible to use single bit instructions, then the copy register could be written into the port data register.

| SET | bit, | datacopy |
|-----|------|----------|
|-----|------|----------|

- LD a, datacopy
- LD DRA, a

The WAIT and STOP instructions allow the ST62xx to be used in situations where low power consumption is needed. The lowest power consumption is achieved by configuring I/Os in input mode with well-defined logic levels.

The user has to take care not to switch outputs with heavy loads during the conversion of one of the analog inputs in order to avoid any disturbance in the measurement.

Figure 25. I/O Port StateTransition Diagram for Safe Transitions



**Note** \*. xxx = DDR, OR, DR Bits respectively



## TIMERS

The ST6245 offers two on-chip Timer peripherals named Timer 1 and Timer 2. Each of these timers consists of an 8-bit counter with a 7-bit programmable prescaler, thus giving a maximum count of 2<sup>15</sup>, and control logic that allows configuring the peripheral in three operating modes. Figure 26 shows the Timer block diagram. Timer 1 only has the external TIMER pin available for the user. The content of the 8-bit counter can be read/written in the Timer/Counter register TCR which is addressed in the data space as a RAM location at addresses D3h or D6h. The state of the 7-bit prescaler can be read in the PSC register at addresses D2h or D5h. The control logic device is managed in the TSCR register (addresses D4h or D7h) as described in the following paragraphs.

The 8-bit counter is decrement by the output (rising edge) coming from the 7-bit prescaler and can be loaded and read under program control. When it decrements to zero then the TMZ (Timer Zero) bit in the TSCR is set to one. If the ETI (Enable Timer Interrupt) bit in the TSCR is also set to one an interrupt request, associated to interrupt vector #3, is generated. The interrupt service routine then would determine which timer reached the end of count by poling the TMZ bits. The Timer interrupt can be used to exit the MCU from the WAIT mode.

The prescaler input can be the oscillator frequency divided by 12 or an external clock at TIMER pin (only Timer 1). The prescaler decrements on the rising edge. Depending on the division factor programmed by PS2, PS1 and PS0 bits in the TSCR, the clock input of the timer/counter register is multiplexed to different sources. On division factor 1, the clock input of the prescaler is also that of timer/counter; on factor 2, bit 0 of prescaler register is connected to the clock input of TCR. This bit changes its state with the half frequency of prescaler clock input. On factor 4, bit 1 of PSC is connected to clock input of TCR, and so on. The prescaler initialize bit (PSI) in the TSCR register must be set to one to allow the prescaler (and hence the counter) to start. If it is cleared to zero then all of the prescaler bits are set to one and the counter is inhibited from counting. The prescaler can be given any value between 0 and 7Fh by writing to addresses D2h or D5h, if bit PSI in the TSCR register is set to one. The tap of the prescaler is selected using the PS2, PS1, PS0 bits in the control register. Figure 27 shows the Timer working principle.



Figure 26. Timer Peripheral Block Diagram



TIMERS (Continued)

## **Timer Operating Modes**

There are 3 operating modes of the Timer peripheral. They are selected by the bits TOUT and DOUT (see TSCR register). These three modes correspond to the two clock frequencies that can be connected on the 7-bit prescaler ( $f_{OSC}/12$  or TIMER pin signal) and to the output mode. For this reason, only Timer 1 has all three modes, while Timer 2, which does not have a dedicated TIMER pin, must be programmed in Output Mode only.

**Clock Input Mode (TOUT = "0", DOUT = "0").** In this mode the TIMER pin is an input and the prescaler is decremented on rising edge. The maximum input frequency that can be applied to the external pin in this mode is 1/8 of the oscillator frequency. This operating mode is not available on Timer 2.

**Gated Mode (TOUT = "0", DOUT = "1").** In this mode the prescaler is decremented by the Timer clock input (oscillator divided by 12) but ONLY when the signal at TIMER pin is held high (giving a pulse width measurement potential). This mode is selected by the TOUT bit in TSCR register cleared to "0" (i.e. as input) and DOUT bit set to "1". This operating mode is not available on Timer 2.

**Output Mode (TOUT = "1", DOUT = data out).** The TIMER pin is connected to the DOUT latch. Therefore the timer prescaler is clocked by the prescaler clock input ( $f_{OSC}/12$ ).

The user can select the desired prescaler division ratio through the PS2, PS1, PS0 bits. When TCR count reaches 0, it sets the TMZ bit in the TSCR. The TMZ bit can be tested under program control to perform a timer function whenever it goes high. The low-to-high TMZ bit transition is used to latch the DOUT bit of the TSCR and pass it to TIMER pin. This operating mode allows external signal generation on the TIMER pin. This is the only operating Mode allowed on Timer 2.

**Table 8. Timer Operating Modes** 

| ΤΟυτ | DOUT | Timer Pin | Timer Function               |
|------|------|-----------|------------------------------|
| 0    | 0    | Input     | Event Counter <sup>(1)</sup> |
| 0    | 1    | Input     | Input Gated <sup>(1)</sup>   |
| 1    | 0    | Output    | Output                       |
| 1    | 1    | Output    | Output                       |

Note 1. Not allowed on Timer 2



## Figure 27. Timer Working Principle

## TIMERS (Continued)

## Timer Interrupt

When the counter register decrements to zero and the software controlled ETI (Enable Timer Interrupt) bit is set to one then an interrupt request associated to interrupt vector #3 is generated. When the counter decrements to zero also the TMZ bit in the TSCR register is set to one.

Since only one interrupt vector is available for the two timers (ORed also with 32kHz oscillator interrupt), the interrupt service routine should determine from which source the interrupt came by polling the TMZ bits (and the OSCEOC bit of the 32kHz oscillator control register).

#### Notes:

TMZ is set when the counter reaches 00h; however, it may be set by writing 00h in the TCR register or setting bit 7 of the TSCR register. TMZ bit must be cleared by user software when servicing the timer interrupt to avoid undesired interrupts when leaving the interrupt service routine. After reset, the 8-bit counter register is loaded to FFh while the 7-bit prescaler is loaded to 7Fh, and the TSCR register is cleared which means that timer is stopped (PSI="0") and the timer interrupt is disabled.

If the Timer is programmed in output mode, DOUT bit is transferred to the TIMER pin when TMZ is set to one (by software or due to counter decrement). When TMZ is high, the latch is transparent and DOUT is copied to the timer pin. When TMZ goes low, DOUT is latched.

A write to the TCR register will predominate over the 8-bit counter decrement to 00h function, i.e. if a write and a TCR register decrement to 00h occur simultaneously, the write will take precedence, and the TMZ bit is not set until the 8-bit counter reaches 00h again. The values of the TCR and the PSC registers can be read accurately at any time.

## Figure 28. Timer Status Control Register



**TMZ.** Low-to-high transition indicates that the timer count register has decremented to zero. This bit must be cleared by user software before starting with a new count.

**ETI.** This bit, when set, enables the timer interrupt request (vector #3). If ETI="0" the timer interrupt is disabled. If ETI="1" and TMZ="1" an interrupt request is generated.

**TOUT.** When low, this bit selects the input mode for the TIMER pin. When high the output mode is selected.

**DOUT.** Data sent to the timer output when TMZ is set high (output mode only). Input mode selection (input mode only). This bit is meaningless for Timer 2.

**PSI.** Used to initialize the prescaler and inhibit its counting. When PSI="0" the prescaler is set to 7Fh and the counter is inhibited. When PSI="1" the prescaler is enabled to count downwards. As long as PSI="0" both counter and prescaler are not running.

**PS2, PS1, PS0.** These bits select the division ratio of the prescaler register.

#### **Table 9. Prescaler Division Factors**

| PS2 | PS1 | PS0 | Divided by | PS2 | PS1 | PS0 | Divided by |
|-----|-----|-----|------------|-----|-----|-----|------------|
| 0   | 0   | 0   | 1          | 1   | 0   | 0   | 16         |
| 0   | 0   | 1   | 2          | 1   | 0   | 1   | 32         |
| 0   | 1   | 0   | 4          | 1   | 1   | 0   | 64         |
| 0   | 1   | 1   | 8          | 1   | 1   | 1   | 128        |

#### Figure 29. Timer Counter Register



#### Figure 30. Prescaler Register





#### DIGITAL WATCHDOG

The digital Watchdog of the ST62 device consists of a down counter that can be used to provide a controlled recovery from a software upset.

The ST6245 watchdog is a the software activated watchdog.

The software activated digital watchdog consists of a down counter that can be used to provide a controlled recovery from a software upset. The watchdog uses one data space register (DWDR location D8h). The watchdog register is set to FEh after reset and the watchdog function is disabled. The watchdog time can be programmed using the 6 Most Significant Bits in the Watchdog register. The check time can be set differently for different routines within the general program.

After a reset the software Watchdog is in the offstate. The watchdog should be activated inside the Reset restart routine by writing a "1" in watchdog timer register bit 0. Bit one of this register must be set to one before programming bit zero as otherwise a reset will be immediately generated when bit 0 is set. This allows the user to generate a reset by software (bit 0 = "1", bit 1 = "0"). Once bit 0 is set, it can not be cleared by software without generating a Reset. The delay time is defined by programming bits 2-7 of the watchdog register. Bit 7 is the Least Significant Bit while bit 2 is the MSB. This gives the possibility to generate a reset in a time between 3072 to 196608 clock cycles in 64 possible steps: (With a clock frequency of 8MHz this means from  $384\mu$ s to 24.576ms). The reset is prevented if the register is reloaded with the desired value before bits 2-7 decrement from all zeros to all ones. If the watchdog is active the STOP instruction is deactivated and a WAIT instruction is automatically executed instead of a STOP. If bit 0 of the watchdog register is never set to one then bits 1-7 of the register can be used as a simple 7-bit counter which is decrement every 3072 clock cycles.

Figure 32. Watchdog Register









## **DIGITAL WATCHDOG** (Continued)

#### Watchdog Register

**C.** This is the watchdog activation bit, that, if set to one, will activate the watchdog function. When cleared to zero it allows the use of the counter as a 7-bit timer. This bit is cleared on reset.

**SR.** This bit is set to one during the reset and will generate a software reset if cleared to zero. When C = "0" (watchdog disabled) it is the MSB of the 7-bit timer.

**T1-T6.** These are the watchdog counter bits. It should be noted that D7 (T1) is the LSB of the counter and D2 (T6) is the MSB of the counter. These bits are in the opposite order to normal.

#### Application note:

If the Watchdog is not used during power-on reset external noise may cause the undesired activation of the Watchdog with a generation of an unexpected reset. To avoid this risk, two additional instructions, that check the state of the watchdog and eventually reset the chip are needed within the first 27 instructions, after the reset. These instructions are:

jrx 0, WD, #+3 ldi WD, 0FDH

These instructions should be executed at the very beginning of the customer program.

If the Watchdog is used during power-on reset the Watchdog register may be set to a low value, that could give a reset after 28 instructions earliest. To avoid undesired resets, the Watchdog must be set to the desired value within the first 27 instructions, the best is to put at the very beginning.

Alternatively the normal legal state can be checked with the following short routine:

ldi a, OFEH and a, WD cpi a, OFEH jrz #+3 ldi WD, OFDH

This sequence is recommended for security applications, where possible stack confusion error loops must be avoided and the Watchdog must only be refreshed after extensive checks.



#### Figure 33. Watchdog Working Principle



## 8-BIT A/D CONVERTER

The A/D converter of ST6245 is an 8-bit analog to digital converter with up to 7 analog inputs (as alternate functions of I/O lines PA5-PA7, PB0-PB3) offering 8-bit resolution with total accuracy  $\pm 2$  LSB and a typical conversion time of 70µs (clock frequency of 8MHz).

The A/D peripheral converts the input voltage by a process of successive approximations using a clock frequency derived from the oscillator with a division factor of twelve. With an oscillator clock frequency less than 1.2MHz, the A/D converter accuracy is decreased.

The selection of the pin signal that has to be converted is done by configuring the related I/O line as analog input through the I/O ports option and data registers (refer to I/O ports description for additional information). Only one I/O line must be configured as analog input at a time. The user must avoid the situation in which more than one I/O pin is selected to be analog input to avoid malfunction of the ST62xx.

The ADC uses two registers in the data space: the ADC data conversion register which stores the conversion result and the ADC control register used to program the ADC functions.

A conversion is started by writing a "1" to the Start bit (STA) in the ADC control register. This automatically clears (resets to "0") the End Of Conversion Bit (EOC). When a conversion has been finished this EOC bit is automatically set to "1" in order to flag that conversion is complete and that the data in the ADC data conversion register is valid. Each conversion has to be separately initiated by writing to the STA bit.

The STA bit is continually being scanned so that if the user sets it to "1" while a previous conversion is in progress then a new conversion is started before the previous one has been completed. The start bit (STA) is a write only bit, any attempt to read it will show a logical "0".

The A/D converter has a maskable interrupt associated to the end of conversion. This interrupt is associated to the interrupt vector #4 and occurs when the EOC bit is set, i.e. when a conversion is completed. The interrupt is masked using the EAI (interrupt mask) bit in the control register.

The power consumption of the device can be reduced by turning off the ADC peripheral. That is achieved when the PDS bit in the ADC control register is cleared to "0". If PDS="1", the A/D is supplied and enabled for conversion. This bit must be set at least one instruction before the beginning of the conversion to allow the stabilization of the A/D converter. *This action is needed also before* 



#### Figure 34. A/D Converter Block Diagram

entering the STOP instruction as the A/D comparator is not automatically disabled by the STOP mode

During reset any conversion in progress is stopped, the control register is reset to all zeros and the A/D interrupt is masked (EAI=0).

#### Notes:

The ST62xx A/D converter does not feature a sample and hold. The analog voltage to be measured should therefore be stable during the conversion time. Variation should not exceed  $\pm 1/2$  LSB for the best accuracy in measurement.

Since the ADC is on the same chip as the microprocessor the user should not switch heavily loaded output signals during conversion if high precision is needed. This is because such switching will affect the supply voltages which are used for comparisons.

A low pass filter can be used at the analog input pins to reduce input voltage variation during the conversion. For true 8 bit conversions the impedance of the analog voltage sources should be less than  $30k\Omega$  while the impedance of the reference voltage should not exceed  $2k\Omega$ .

The accuracy of the conversion depends on the quality of the power supply voltages ( $V_{DD}$  and  $V_{SS}$ ). The user must specially take care of applying regulated reference voltage on the  $V_{DD}$  and  $V_{SS}$  pins (the variation of the power supply voltage must be inferior to 5V/ms).

The converter can resolve the input voltage with a resolution of:

$$\frac{V_{DD}-V_{SS}}{256}$$



## 8-BIT A/D CONVERTER(Continued)

The Input voltage (Ain) which has to be converted must be constant for  $1\mu s$  before conversion and remain constant during the conversion.

The resolution of the conversion can be improved if the power supply voltage (V<sub>DD</sub>) of the microcontroller becomes lower.

In order to optimize the resolution of the conversion, the user can configure the microcontroller in the WAIT mode because this mode allows the minimization of the noise disturbances and the variations of the power supply voltages due to the switching of the outputs. Nevertheless, it must be take care of executing the WAIT instruction as soon as possible after the beginning of the conversion because the execution of the WAIT instruction may provide a small variation of the V<sub>DD</sub> voltage (the negative effect of this variation is minimized at the beginning of the conversion because the latter is less sensitive than the end of the conversion when the less significant bits are determined).

The best configuration from a accuracy point of view is the WAIT mode with the Timer and LCD driver stopped. Indeed, only the ADC peripheral and the oscillator are still working. The MCU has to be wake-up from the WAIT mode by the interrupt of the ADC peripheral at the end of the conversion. It must be noticed that the wake-up of the micro-controller could be done also with the interrupt of the TIMER, but in this case, the Timer is working and some noise could disturb the converter in terms of accuracy.

## Figure 35. A/D Converter Control Register



**EAI.** If this bit is set to one the A/D interrupt (vector #4) is enabled, when EAI=0 the interrupt is disabled.

**EOC.** Read Only; This read only bit indicates when a conversion has been completed. This bit is automatically reset to zero when the STA bit is written. If the user is using the interrupt option then this bit can be used as an interrupt pending bit. Data in the data conversion register are valid only when this bit is set to one.

**STA.** *Write Only*; Writing a "1" in this bit will start a conversion on the selected channel and automatically reset to zero the EOC bit. If the bit is set again when a conversion is in progress, the present conversion is stopped and a new one will take place. This bit is write only, any attempt to read it will show a logical zero.

**PDS.** This bit activates the A/D converter if set to 1. Writing a zero into this bit will put the ADC in power down mode (idle mode).

D3-D0. Not used





**D7-D0.** Read Only, These are the conversion result bits; the register is read only and stores the result of the last conversion. The contents of this register are valid only when EOC bit in the ADCR register is set to one (end-of-conversion).



#### 32kHz STAND-BY OSCILLATOR

The 32kHz stand-by oscillator allows the ST6245 to generate real time interrupts and to supply the clock to the LCD driver. This enables the ST6245 to provide real time functions with the LCD display capability and lower power consumption. Figure 37 shows the 32kHz oscillator block diagram.

A 32.768kHz quartz crystal must be connected to the OSC32in and OSC32out pins to perform the real time clock operation. Two external capacitors of 15-22pF each must be connected between the oscillator pins and ground. The 32kHz oscillator is managed by the dedicated status/control register located at address 0DBh.

When the 32kHz stand-by oscillator is stopped (bit 5 of the Status/Control register cleared) the divider chain is supplied with a clock signal synchronous with machine cycle ( $f_{OSC}/13$ ), this produces an interrupt request every  $13x2^{14}$  clock cycle (i.e. 26.624ms) with an 8MHz quartz crystal.

When the 32kHz stand-by oscillator is enabled (bit 5 of the Status/Control register set to one) the divider chain is directly supplied with the 32kHz oscillator clock. The 32kHz clock from the standby oscillator can also be used as the LCD clock. This allows operation of the LCD in STOP mode. The interrupt output of the 32kHz oscillator peripheral generates an interrupt request every half second (500ms). This can be used to perform a real time clock function when the MCU is in STOP mode.

This interrupt signal is "ORed" with the interrupt request signals of the two on-chip timers and connected to the low level sensitive interrupt input associated to the interrupt vector #3 (FF2h, FF3h). The interrupt request has to be cleared by user software before leaving the interrupt service routine. Discrimination between the three interrupt sources is made by polling the Status/Control registers of Timer 1 (D4h), Timer 2 (D7h) and 32kHz oscillator (DBh).





## 32kHz STAND-BY OSCILLATOR (Continued)

## 32kHz Oscillator Status/Control Register

#### Figure 38. 32kHz Oscillator Register



**EOSCI.** Enable Oscillator Interrupt. This bit, when set, enables the 32kHz oscillator interrupt request.

**OSCEOC.** Oscillator Interrupt Flag. This bit indicates when the 32kHz oscillator has measured a

#### SERIAL PERIPHERAL INTERFACE (SPI)

The ST6245 SPI is an optimized serial synchronous interface that supports a wide range of industry standard SPI specifications. The ST6245 SPI is controlled by small and simple user software to perform serial data exchange. The serial shift clock can be implemented either by software (using the bit-set and bit-reset instructions), with the on-chip Timer 1 by externally connecting the SPI clock pin to the timer pin or by directly applying an external clock to the SPI.

The peripheral is composed by an 8-bit Data/shift Register (address DDh) and a 4-bit binary counter. The SCL, Sin and Sout SPI data and clock signals are connected to the PB5, PB6 and PB7 I/O lines. With the 3 I/O pins, the SPI can operate in the following operating modes: Software SPI, S-BUS, I<sup>2</sup>C-bus and as a standard serial I/O (clock, data, enable). An interrupt request can be generated after eight clock pulses. Figure 40 shows the SPI block diagram.





500ms elapsed time (providing a 32.768kHz quartz crystal is connected to the 32kHz oscillator dedicated pins). An interrupt request can be generated in relation to the state of EOSCI bit. This bit must be cleared by the user program before leaving the interrupt service routine.

**START/STOP.** Oscillator Start/Stop bit. This bit, when set, enables the 32kHz stand-by oscillator and the free running divider chain is supplied by the 32kHz oscillator signal. When this bit is cleared to zero the divider chain is supplied with the clock signal from the LCD Controller.

This register is cleared during reset.

#### Note:

To achieve minimum power consumption in STOP mode (no system clock), the stand-by oscillator must be switched off (real time function not available) by clearing the Start/Stop bit in the oscillator status/control register.

The PB5/SCL line clocks, on the falling edge, the shift register and the counter. To allow SPI operation the PB5/SCL must be programmed as input, an external clock supplied to this pin will drive the SPI peripheral (slave mode).

If PA5/SCL is programmed as output, a clock signal can be generated by software, setting and resetting the port line by software (master mode).

The SCL clock signal is the shift clock for the SPI data/shift register. The PB6/Sin pin is the serial shift input and PB7/Sout is the serial shift output. These two lines can be tied together to implement two wires protocols (I<sup>2</sup>C-bus, etc). When data is serialized, the MSB is the first bit. PB6/Sin has to be programmed as input. For serial output operation PB7/Sout has to be programmed as open-drain output.

After 8 clock pulses (D7..D0) the output  $\overline{Q4}$  of the 4-bit binary counter becomes low, disabling the clock from the counter and the data/shift register. Q4 enables the clock to generate an interrupt on the 8th clock falling edge as long as no reset of the counter (processor write into the 8-bit data/shift register) takes place. After a processor reset the interrupt is disabled. The interrupt is active when writing data in the shift register (DDh) and desactivated when writing any data in the register SPI Interrupt Disable (C2h).



## SERIAL PERIPHERAL INTERFACE (Continued)

The generation of an interrupt to the Core provides information that new data is available (input mode) or that transmission is completed (output mode), allowing the Core to generate an acknowledge on the 9th clock pulse (I<sup>2</sup>C-bus).

Since the SPI interrupt is connected to interrupt #1, the falling edge interrupt option should be selected by clearing to zero bit 6 of the Interrupt Option Register (IOR, C8h).

After power on reset, or after writing the data/shift register, the counter is reset to zero and the clock is enabled. In this condition the data shift register is ready for reception. No start condition has to be detected. Through the user software the Core may pull down the Sin line (Acknowledge) and slow down the SCL, as long as it is needed to carry out data from the shift register.

#### I<sup>2</sup>C-bus Master-Slave, Receiver-Transmitter

When pins Sin and Sout are externally connected togetherit is possible to use the SPI as a receiver as well as a transmitter. With a simple software routine (by using bit-set and bit-reset on I/O line) a clock can be generated allowing I<sup>2</sup>C-bus to work in master mode.

When implementing an  $l^2$ C-bus protocol, the start condition can be detected by setting the processor into a "wait for start" condition by simply enabling the interrupt of the PA6/Sin I/O port. This frees the processor from polling the Sin and SCL lines. After the transmission/reception the processor has to poll for the STOP condition. In slave mode the user software can slow down the SCL clock frequency by simply putting the SCL I/O line in output open-drain mode and writing a zero into the corresponding data register bit.

As it is possible to directly read the Sin pin directly through the port register, the software can detect a difference between internal data and external data (master mode). Similar condition can be applied to the clock.

The typical speed of transmission in  $I^2C$  master or slave mode is in the range of 10kHz.

#### Three (Four) Wire Serial Bus

It is possible to use a single general purpose I/O pin (with the corresponding interrupt enabled) as a "chip enable" pin. SCL acts as active or passive clock pin, Sin as data in and Sout as data out (four wire bus). Sin and Sout can be connected together externally to implement three wire bus.

#### Note:

When the SPI is not used, the three I/O lines (Sin, SCL, Sout) can be used as normal I/O, with the following limitation: bit Sout cannot be used in open drain mode as this enables the shift register output to the port.

It is recommended, in order to avoid spurious interrupts from the SPI, to disable the SPI interrupt (the default state after reset) i.e. no write must be made to the 8-bit shift register (DDh). An explicit interrupt disable may be made in software by a dummy write to address C2h.



## Figure 40. SPI Block Diagram



## LCD CONTROLLER-DRIVER

The ST6245 LCD driver consists of a LCD control logic, a programmable prescaler, a 12 bytes wide dedicated LCD RAM, 24 segment and 4 common outputs. This allows a direct driving of up to 96 LCD segments.

The LCD driver is managed by the LCD Mode/Control register located at data RAM address DCh. Different display modes (1/1 duty, 1/2 duty, 1/3 duty and 1/4 duty) are available to cover a wide range of application requirements. The multiplexing display modes are software selectable by programming bits 6 and 7 of the LCD control register. Bits 0-5 are used to select the LCD drive and frame frequency (in relation to the system clock) and to switch off all segments. The LCD Driver can also be supplied by the 32kHz real-time oscillator allowing working in low power conditions and performing real time clock operation.

According to the data in the LCD RAM, the segment and the common drivers generate the segment and common signals which can directly drive an LCD panel.

The LCD control logic reads automatically the data from the LCD RAM independently and without interruption of the processor. The part of the LCD RAM that is not used for displaying can be used as normal data memory.

The scale factor of the clock prescaler can be fixed by software, therefore different frame frequencies can be defined.

The ST6245 oscillator should operate with a 1.0486, 2.0972, 4.1943, 8.3886MHz frequency quartz crystal. This allows the associated division rates to achieve an internal reference frequency of 32.768kHz. The different division rates can be achieved by programming bits 3, 4, 5 in the LCD control register (see Table 11). It is not recommended to select an internal frequency lower than 32.768kHz as the clock supervisor circuit may switch off the LCD peripheral if the lower frequency is detected.

When the display is turned off, all segment and common outputs are switched to ground, causing all the segments to be switched off regardless of the contents of the LCD RAM.

When the Stand-by oscillator function is selected, the 32kHz stand-by oscillator is selected as clock source for the LCD.

To avoid incomplete frames of the LCD, the mode control bits do not immediately influence the LCD controller when the LCD control register is written. They are stored in a temporary register and change the LCD function only at the end of the frame. Special care must be taken when entering the STOP mode. After switching the LCD clock source from the main oscillator to the 32kHz standby oscillator it must be guaranteed that enough clock pulses are delivered to complete the current frame before entering the STOP mode. Otherwise the LCD function will not be changed and the LCD will be switched OFF after entering the STOP mode. Different LCD frame frequencies for each display mode are selected by bits in the LCD control register (see Table 12).





**DS0, DS1.** Duty cycle select bits. These bits select the number of common backplanes used by the LCD control. This allows different multiplexing conditions.

**HF0, HF1, HF2.** These bits allow the LCD controller to be supplied with the correct frequency when different high main oscillator frequencies are selected as system clock. Table 11 shows the set-up for different clock crystals.

**LF0, LF1, LF2.** These bits control the LCD base operational frequency of the LCD common lines. Table 12 shows the set-up to select the different

Table 10. Duty Cycle Selection

| DS1 | DS0 | Display<br>Mode | Active<br>Blackplanes | Max.<br>Number of<br>Segments<br>Driven |
|-----|-----|-----------------|-----------------------|-----------------------------------------|
| 0   | 0   | 1/4 duty        | COM1, 2, 3, 4         | 180                                     |
| 0   | 1   | 1/1 duty        | COM1                  | 45                                      |
| 1   | 0   | 1/2 duty        | COM1, 2               | 90                                      |
| 1   | 1   | 1/3 duty        | COM1, 2, 3            | 135                                     |



## Table 11. High Frequency Select Bits

| HF2 | HF1 | HF0 | Function                  | fosc      |
|-----|-----|-----|---------------------------|-----------|
| 0   | 0   | 0   | Display off               |           |
| 0   | 0   | 1   | for stand-by Oscillator   | 32.768kHz |
| 0   | 1   | 0   | NOT TO BE USED            |           |
| 0   | 1   | 1   | ÷ 32 for main oscillator  | 1.048MHz  |
| 1   | 0   | 0   | ÷ 64 for main oscillator  | 2.097MHz  |
| 1   | 0   | 1   | ÷ 128 for main oscillator | 4.194MHz  |
| 1   | 1   | 0   | ÷ 256 for main oscillator | 8.388MHz  |
| 1   | 1   | 1   | NOT TO BE USED            |           |

Notes :

1. The usage fosc values different from those defined in this table cause the LCD to operate at a reference frequency different from 32.768kHz.

2. It is not recommended to select an internal frequency lower than 32.768kHz as the clock supervisor circuit may switch off the LCD peripheral if lower frequency is detected.

| LF2 | LF1 | LF0 | f <sub>LCD</sub> (Hz) |
|-----|-----|-----|-----------------------|
| 0   | 0   | 0   | 64                    |
| 0   | 0   | 1   | 85                    |
| 0   | 1   | 0   | 128                   |
| 0   | 1   | 1   | 171                   |
| 1   | 0   | 0   | 256                   |
| 1   | 0   | 1   | 341                   |
| 1   | 1   | 0   | 512                   |
| 1   | 1   | 1   | Not to be Used        |

#### Table 12. LCD Frequency Select Bits

frequencies while Table 13 shows the corresponding frame values with the different multiplexing conditions.

According to the selected LCD drive frequency  $f_{LCD}$  the frame frequencies come out as shown in Table 13.

The Figure 48 illustrates the waveforms of the different duty signals.

#### Table 13. Available Frame Frequencies for LCD

| f <sub>LCD</sub> | Frame Frequency f <sub>F</sub> (Hz) |     |          |          |  |  |  |  |
|------------------|-------------------------------------|-----|----------|----------|--|--|--|--|
| (Hz)             | 1/1 duty 1/2 duty 1/3 dut           |     | 1/3 duty | 1/4 duty |  |  |  |  |
| 512              | 512                                 | 256 | 171      | 128      |  |  |  |  |
| 341              | 341                                 | 171 | 114      | 85       |  |  |  |  |
| 256              | 256                                 | 128 | 85       | 64       |  |  |  |  |
| 171              | 171                                 | 85  | 57       | 43       |  |  |  |  |
| 128              | 128                                 | 64  | 43       | 32       |  |  |  |  |
| 85               | 85                                  | 43  | 28       | 21       |  |  |  |  |
| 64               | 64                                  | 32  | 21       | 16       |  |  |  |  |

The value of the VLCD voltage can be chosen independently from  $V_{DD}$  according to the display requirements. The intermediate VLCD levels 2/3 VLCD, 1/3 VLCD and 1/2 VLCD are generated by an internal resistor network as shown in Figures 46 and 47. The half VLCD level for 1/2 duty cycle is obtained by the external connection of VLCD1/3 and VLCD2/3 pins. All intermediate VLCD levels are connected to pins to enable external capacitive buffering or resistive shunting.



The internal resistive divider network is realized with two parallel dividers. One has high resistivity, the other one low resistivity. The high resistive divider ( $R_H$ ) is permanently switched on during the LCD operation. The low resistive divider ( $R_L$ ) is only switched on for a short period of time when the levels of common lines and segment lines are changed. This method combines low source impedance for fast switching of the LCD pixels with high source impedance for low power consumption. Figure 42 shows the typical current into V<sub>LCD</sub> pin in dependency of the display voltage V<sub>LCD</sub>.

## Figure 42. Typical Current Consumption on VLCD Pin (25°C, no load, fLCD= 512Hz, mux= 1/3-1/4)



When the display is switched off (by program or reset) the internal resistor network is also switched off to achieve minimum power consumption. The low resistivity divider is active at each edge of  $f_{LCD}$  during 8 clock cycles of  $F_{32kHz}$ .

The internal resistor network is implemented with resistive transistor elements to achieve high precision. For display voltages  $V_{LCD} < 4.5V$  the resistivity of the divider may be too high for some applications (especially using 1/3 or 1/4 duty display mode). In that case an external resistive divider must be used to achieve the desired resistivity.

## Figure 43. Typical Chronogram of Activation of the $V_{LCD}$ Divider Network





Typical External resistances values are in the range of 100 k $\Omega$  to 150 k $\Omega$ . External capacitances in the range of 10 to 47 nF can be added to V<sub>LCD</sub> 2/3 and V<sub>LCD</sub> 1/3 pins and to V<sub>LCD</sub> if the V<sub>LCD</sub> connection is highly impedant.

When the program is switched off (by program or reset) the internal resistor network is also switched off to achieve minimum power consumption.

## Figure 44. Typical Network to connect to $V_{LCD}$ pins if $V_{LCD} \leq 4.5V$



## Figure 45. Generation of the 32kHz clock



## Figure 46. Bias Config for 1/2 Duty



# Figure 47. Bias Configuration for 1/1, 1/3 and 1/4 Duty Operation of LCD





#### Address Mapping of the Display Segments.

The LCD RAM is located in the ST6245 data space from addresses E0h to F7h. The LCD forms a matrix of 24 segment lines (rows) and up to 4 common lines (columns). Each bit of the LCD RAM is mapped to one element of the LCD matrix, as described in Figure 49. If a bit is set, the corresponding LCD segment is switched on; if it is reset, the segment is switched off. The segments outputs S1-S16 and S41-S48 are not connected to any pin.

When multiplex rates lower than 1/4 are selected, the unused LCD RAM is free for general use. In the 1/2 duty mode, for instance, half of the LCD RAM is available for storing general purpose data. The address range from F8h to FEh can be used as general purpose data RAM, but not for displaying data (it is reserved for future LCD expansion).

After a reset, the LCD RAM is not initializated and contains arbitrary information. As the LCD control register is reset, the LCD is completely switched off.



## Figure 48. Common Signal Waveforms



## Figure 49. Addressing Map of the LCD RAM

| Data RAM<br>Address | MSB        |            |            |            |            |                |            | LSB        |      |
|---------------------|------------|------------|------------|------------|------------|----------------|------------|------------|------|
| E0*<br>E1*          |            |            |            |            |            |                |            |            |      |
| E2                  | S24        | S23        | S22        | S21        | S20        | S19            | S18        | S17        | COM1 |
| E3<br>E4            | S32<br>S40 | S31<br>S39 | S30<br>S38 | S29<br>S37 | S28<br>S36 | S27<br>S35     | S26<br>S34 | S25<br>S33 |      |
| E4<br>E5*           | 540        | 239        | 538        | 537        | 530        | 535            | 534        | 533        |      |
| E6*                 |            |            |            |            |            |                |            |            |      |
| E7*<br>E8           | S24        | S23        | S22        | S21        | S20        | S19            | S18        | S17        |      |
| E9                  | S32        | S31        | S30        | S29        | S28        | S27            | S26        | S25        | COM2 |
| EA                  | S40        | S39        | S38        | S37        | S36        | S35            | S34        | S33        |      |
| EB*                 |            |            |            |            |            |                |            |            |      |
| EC*                 |            |            |            |            |            |                |            |            |      |
| ED*                 |            |            |            |            |            |                |            | - · -      |      |
| EE<br>EF            | S24<br>S32 | S23<br>S31 | S22<br>S30 | S21<br>S29 | S20<br>S28 | S19<br>S27     | S18<br>S26 | S17<br>S25 | COM3 |
| EF<br>F0            | S32        | S31<br>S39 | S30<br>S38 | 529<br>S37 | S28<br>S36 | S27<br>S35     | 526<br>S34 | S25<br>S33 |      |
| F1*                 |            | 000        | 000        | 001        | 000        | 000            | 001        | 000        |      |
| F2*                 |            |            |            |            |            |                |            |            |      |
| F3*                 |            |            |            |            |            | <b>-</b> · · - |            | - · -      |      |
| F4                  | S24        | S23        | S22        | S21        | S20        | S19            | S18        | S17        | COM4 |
| F5<br>F6            | S32<br>S40 | S31<br>S39 | S30<br>S38 | S29<br>S37 | S28<br>S36 | S27<br>S35     | S26<br>S34 | S25<br>S33 |      |
| F7*                 | 040        | 009        | 000        | 007        | 000        | 000            | 004        | 000        |      |
| F8 - FE*            |            |            |            |            |            |                |            |            |      |
| 0-FE                |            |            |            |            |            |                |            |            |      |

Note: \*. Row to be used as general purpose data RAM (not for display data)

#### Notes:

In STOP mode no clock is available for the LCD controller from the main oscillator. If the 32kHz oscillator is activated the LCD can also operate in STOP mode. If the stand-by oscillator is not active, the LCD controller is switched off when STOP instruction is executed; this mode has to be selected to reach the lowest power consumption.

A missing LCD clock (no oscillator active, broken crystal, etc.) is detected by a clock supervisor circuit that switches all the segments and common lines to ground to avoid destructive DC levels at the LCD.

The LCD function change is only effective at the end of a frame. For this reason special care has to be taken when entering the STOP mode. After switching the LCD clock source from the main oscillator to the 32kHz stand-by oscillator it must be guaranteed that enough clock pulses are delivered to complete the current frame before entering the STOP mode. Otherwise the LCD function will not be changed and the LCD is switched off after entering the STOP mode.

The RAM address F8-FEh are not used for LCD display purposes. So they are available as 7 additional Data RAM registers.



#### SOFTWARE DESCRIPTION

The ST62xx software has been designed to fully use the hardware in the most efficient way possible while keeping byte usage to a minimum, in short to provide byte efficient programming capability. The ST62xx core has the ability to set or clear any register or RAM location bit of the Data space with a single instruction. Furthermore, the program may branch to a selected address depending on the status of any bit of the Data space. The carry bit is stored with the value of the bit when the SET or RES instruction is processed.

#### Addressing Modes

The ST62xx core has nine addressing modes which are described in the following paragraphs. The ST62xx core uses three different address spaces: Program space, Data space, and Stack space. Program space contains the instructions which are to be executed, plus the data for immediate mode instructions. Data space contains the Accumulator, the X,Y,V and W registers, peripheral and Input/Output registers, the RAM locations and Data ROM locations (for storage of tables and constants). Stack space contains six 12-bit RAM cells used to stack the return addresses for subroutines and interrupts.

**Immediate.** In the immediate addressing mode, the operand of the instruction follows the opcode location. As the operand is a ROM byte, the immediate addressing mode is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter).

**Direct.** In the direct addressing mode, the address of the byte that is processed by the instruction is stored in the location that follows the opcode. Direct addressing allows the user to directly address the 256 bytes in Data Space memory with a single two-byte instruction.

**Short Direct.** The core can address the four RAM registers X,Y,V,W (locations 80h, 81h, 82h, 83h) in the short-direct addressing mode . In this case, the instruction is only one byte and the selection of the location to be processed is contained in the op-code. Short direct addressing is a subset of the direct addressing mode. (Note that 80h and 81h are also indirect registers).

**Extended.** In the extended addressing mode, the 12-bit address needed to define the instruction is obtained by concatenating the four less significant bits of the opcode with the byte following the opcode. The instructions (JP, CALL) that use the extended addressing mode are able to branch to any address of the 4K bytes Program space.

An extended addressing mode instruction is twobyte long. Program Counter Relative. The relative addressing mode is only used in conditional branch instructions. The instruction is used to perform a test and, if the condition is true, a branch with a span of -15 to +16 locations around the address of the relative instruction. If the condition is not true, the instruction that follows the relative instruction is executed. The relative addressing mode instruction is onebyte long. The opcode is obtained in adding the three most significant bits that characterize the kind of the test, one bit that determines whether the branch is a forward (when it is 0) or backward (when it is 1) branch and the four less significant bits that give the span of the branch (0h to Fh) that must be added or subtracted to the address of the relative instruction to obtain the address of the branch.

**Bit Direct.** In the bit direct addressing mode, the bit to be set or cleared is part of the opcode, and the byte following the opcode points to the address of the byte in which the specified bit must be set or cleared. Thus, any bit in the 256 locations of Data space memory can be set or cleared.

**Bit Test & Branch.** The bit test and branch addressing mode is a combination of direct addressing and relative addressing. The bit test and branch instruction is three-byte long. The bit identification and the tested condition are included in the opcode byte. The address of the byte to be tested follows immediately the opcode in the Program space. The third byte is the jump displacement, which is in the range of -126 to +129. This displacement can be determined using a label, which is converted by the assembler.

**Indirect.** In the indirect addressing mode, the byte processed by the register-indirect instruction is at the address pointed by the content of one of the indirect registers, X or Y (80h,81h). The indirect register is selected by the bit 4 of the opcode. A register indirect instruction is one byte long.

**Inherent.** In the inherent addressing mode, all the information necessary to execute the instruction is contained in the opcode. These instructions are one byte long.



#### **Instruction Set**

The ST62xx core has a set of 40 basic instructions. When these instructions are combined with nine addressing modes, 244 usable opcodes can be obtained. They can be divided into six different types:load/store, arithmetic/logic, conditional branch, control instructions, jump/call, bit manipulation. The following paragraphs describe the different types.

All the instructions within a given type are presented in individual tables. **Load & Store.** These instructions use one,two or three bytes in relation with the addressing mode. One operand is the Accumulator for LOAD and the other operand is obtained from data memory using one of the addressing modes.

For Load Immediate one operand can be any of the 256 data space bytes while the other is always immediate data.

| Instruction | Addrossing Made | Butoo | Cycles | Fla | Flags |  |  |
|-------------|-----------------|-------|--------|-----|-------|--|--|
| Instruction | Addressing Mode | Bytes | Cycles | Z   | С     |  |  |
|             |                 |       |        |     |       |  |  |
| LD A, X     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD A, Y     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD A, V     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD A, W     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD X, A     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD Y, A     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD V, A     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD W, A     | Short Direct    | 1     | 4      | Δ   | *     |  |  |
| LD A, rr    | Direct          | 2     | 4      | Δ   | *     |  |  |
| LD rr, A    | Direct          | 2     | 4      | Δ   | *     |  |  |
| LD A, (X)   | Indirect        | 1     | 4      | Δ   | *     |  |  |
| LD A, (Y)   | Indirect        | 1     | 4      | Δ   | *     |  |  |
| LD (X), A   | Indirect        | 1     | 4      | Δ   | *     |  |  |
| LD (Y), A   | Indirect        | 1     | 4      | Δ   | *     |  |  |
|             |                 |       |        |     |       |  |  |
|             |                 |       |        |     |       |  |  |
| LDI A, #N   | Immediate       | 2     | 4      | Δ   | *     |  |  |
| LDI rr, #N  | Immediate       | 3     | 4      | *   | *     |  |  |
|             |                 |       |        |     |       |  |  |

## Table 14. Load & Store Instructions

Notes:

X,Y. Indirect Register Pointers, V & W Short Direct Registers

# . Immediate data (stored in ROM memory)

rr. Data space register

 $\Delta$  . Affected

\*. Not Affected



Arithmetic and Logic. These instructions are used to perform the arithmetic calculations and logic operations. In AND, ADD, CP, SUB instructions one operand is always the accumulator while the other can be either a data space memory content or an immediate value in relation with the addressing mode. In CLR, DEC, INC instructions the operand can be any of the 256 data space addresses. In COM, RLC, SLA the operand is always the accumulator.

| I                                                                         |                                                                                                          | Defe                            | Quality                                   | Flags                                                 |                                                                          |  |
|---------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|---------------------------------|-------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------|--|
| Instruction                                                               | Addressing Mode                                                                                          | Bytes                           | Cycles                                    | Z                                                     | С                                                                        |  |
| ADD A, (X)<br>ADD A, (Y)<br>ADD A, rr                                     | Indirect<br>Indirect<br>Direct                                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $\Delta$<br>$\Delta$<br>$\Delta$                      | $egin{array}{c} \Delta & \ \Delta & \ \Delta & \ \Delta & \ \end{array}$ |  |
| ADDI A, #N                                                                | Immediate                                                                                                | 2                               | 4                                         | Δ                                                     | Δ                                                                        |  |
| AND A, (X)<br>AND A, (Y)<br>AND A, rr                                     | Indirect<br>Indirect<br>Direct                                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $\Delta$<br>$\Delta$<br>$\Delta$                      | * * *                                                                    |  |
| ANDI A, #N                                                                | Immediate                                                                                                | 2                               | 4                                         | Δ                                                     | *                                                                        |  |
| CLR A<br>CLR rr                                                           | Short Direct<br>Direct                                                                                   | 2<br>3                          | 4<br>4                                    | Δ<br>*                                                | Δ<br>*                                                                   |  |
| COM A                                                                     | Inherent                                                                                                 | 1                               | 4                                         | Δ                                                     | Δ                                                                        |  |
| CP A, (X)<br>CP A, (Y)<br>CP A, rr                                        | Indirect<br>Indirect<br>Direct                                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $\Delta$<br>$\Delta$<br>$\Delta$                      | $egin{array}{c} \Delta & \ \Delta & \ \Delta & \ \Delta & \ \end{array}$ |  |
| CPI A, #N                                                                 | Immediate                                                                                                | 2                               | 4                                         | Δ                                                     | Δ                                                                        |  |
| DEC X<br>DEC Y<br>DEC V<br>DEC W<br>DEC A<br>DEC rr<br>DEC (X)<br>DEC (Y) | Short Direct<br>Short Direct<br>Short Direct<br>Short Direct<br>Direct<br>Direct<br>Indirect<br>Indirect | 1<br>1<br>1<br>2<br>2<br>1<br>1 | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 | Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ                       | *<br>*<br>*<br>*<br>*<br>*                                               |  |
| INC X<br>INC Y<br>INC V<br>INC W<br>INC A<br>INC rr<br>INC (X)<br>INC (Y) | Short Direct<br>Short Direct<br>Short Direct<br>Direct<br>Direct<br>Indirect<br>Indirect                 | 1<br>1<br>1<br>2<br>2<br>1<br>1 | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 | Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ<br>Δ                       | *<br>*<br>*<br>*<br>*                                                    |  |
| RLC A                                                                     | Inherent                                                                                                 | 1                               | 4                                         | Δ                                                     | Δ                                                                        |  |
| SLA A                                                                     | Inherent                                                                                                 | 2                               | 4                                         | Δ                                                     | Δ                                                                        |  |
| SUB A, (X)<br>SUB A, (Y)<br>SUB A, rr                                     | Indirect<br>Indirect<br>Direct                                                                           | 1<br>1<br>2                     | 4<br>4<br>4                               | $egin{array}{c} \Delta \ \Delta \ \Delta \end{array}$ | $egin{array}{c} \Delta \ \Delta \ \Delta \end{array}$                    |  |
| SUBI A, #N                                                                | Immediate                                                                                                | 2                               | 4                                         | Δ                                                     | Δ                                                                        |  |

#### Table 15. Arithmetic & Logic Instructions

Notes:

# . Immediate data (stored in ROM memory)

rr. Data space register

∆. Affected\* . Not Affected

SGS-THOMSON MICROELECTRONICS

X,Y. Indirect Register Pointers, V & W Short Direct Registers

**Conditional Branch.** The branch instructions achieve a branch in the program when the selected condition is met.

**Bit Manipulation Instructions.** These instructions can handle any bit in data space memory. One group either sets or clears. The other group (see Conditional Branch) performs the bit test branch operations. **Control Instructions.** The control instructions control the MCU operations during program execution.

**Jump and Call.** These two instructions are used to perform long (12-bit) jumps or subroutines call inside the whole program space.

rr. Data space register

Not Affected

 $\Delta$ . Affected

\* . Not Affected

#### **Table 16. Conditional Branch Instructions**

| Instruction   | Branch If | Button | Civalaa | Flags |   |  |
|---------------|-----------|--------|---------|-------|---|--|
| instruction   | Branch II | Bytes  | Cycles  | Z     | С |  |
| JRC e         | C = 1     | 1      | 2       | *     | * |  |
| JRNC e        | C = 0     | 1      | 2       | *     | * |  |
| JRZ e         | Z = 1     | 1      | 2       | *     | * |  |
| JRNZ e        | Z = 0     | 1      | 2       | *     | * |  |
| JRR b, rr, ee | Bit = 0   | 3      | 5       | *     | Δ |  |
| JRS b, rr, ee | Bit = 1   | 3      | 5       | *     | Δ |  |

Notes:

b. 3-bit address

e. 5 bit signed displacement in the range -15 to +16

ee. 8 bit signed displacement in the range -126 to +129

#### Table 17. Bit Manipulation Instructions

| Instruction | Addrossing Mode | Button | Cycles       | Flags |   |  |
|-------------|-----------------|--------|--------------|-------|---|--|
| Instruction | Addressing Mode | Byles  | Bytes Cycles | Z     | С |  |
| SET b,rr    | Bit Direct      | 2      | 4            | *     | * |  |
| RES b,rr    | Bit Direct      | 2      | 4            | *     | * |  |

Notes:

b. 3-bit address;

rr. Data space register;

#### Table 18. Control Instructions

| Instruction | Addrossing Made | Buttoo | Civalaa | Flags    |   |  |
|-------------|-----------------|--------|---------|----------|---|--|
| Instruction | Addressing Mode | Bytes  | Cycles  | Z        | С |  |
| NOP         | Inherent        | 1      | 2       | *        | * |  |
| RET         | Inherent        | 1      | 2       | *        | * |  |
| RETI        | Inherent        | 1      | 2       | $\Delta$ | Δ |  |
| STOP (1)    | Inherent        | 1      | 2       | *        | * |  |
| WAIT        | Inherent        | 1      | 2       | *        | * |  |

Notes:

1. This instruction is deactivated and a WAIT is automatically executed instead of a STOP if the Watchdog function is selected.

 $\Delta$ . Affected

\* . Not Affected

#### Table 19. Jump & Call Instructions

| Instruction | Addressing Mede | Bytes Cycles |        | Flags |   |  |
|-------------|-----------------|--------------|--------|-------|---|--|
| Instruction | Addressing Mode | Byles        | Cycles | Z     | С |  |
| CALL abc    | Extended        | 2            | 4      | *     | * |  |
| JP abc      | Extended        | 2            | 4      | *     | * |  |

Notes:

abc.12-bit address; \* . Not Affected

. Not Affected



Opcode Map Summary. The following table contains an opcode map for the instructions used on the MCU.

| LOW       | 0                      | 1<br>0001       | 2<br>0010              | 3<br>0011            | 4<br>0100             | 5<br>0101 |        | 6<br>110   | 7<br>0111      | 8<br>1000              | 9<br>1001            | A<br>1010              | В<br>1011             |     | C<br>1100  | D             |       | E<br>1110  | F<br>1111             | LOW       |
|-----------|------------------------|-----------------|------------------------|----------------------|-----------------------|-----------|--------|------------|----------------|------------------------|----------------------|------------------------|-----------------------|-----|------------|---------------|-------|------------|-----------------------|-----------|
| н 🔪       | 0000                   | 0001            | 0010                   | 0011                 | 0100                  | 0101      | 0      | 110        | 0111           | 1000                   | 1001                 | 1010                   | 1011                  | 1   | 1100       | 1101          | 1     | 110        | 1111                  | н         |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |           | 2      | JRC        | 4 LD           | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2   | JRZ        | 4 LD          | 12    | JRC        | 4 LD                  |           |
| 0000      | е                      | abc             | е                      | b0,rr,ee             | е                     | #         |        | е          | a,(x)          | е                      | abc                  | е                      | b0,rr                 |     | е          | rr,nn         |       | е          | a,(y)                 | 0000      |
| 0000      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1      | prc        | 1 ind          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 3 imm         | 1     | pcr        | 1 ind                 |           |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 INC     | 2      | JRC        | 4 LDI          | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 DEC         | 2     | JRC        | 4 LD                  |           |
| 1<br>0001 | е                      | abc             | е                      | b0,rr,ee             | е                     | х         |        | е          | a,nn           | е                      | abc                  | е                      | b0,rr                 |     | е          | х             |       | е          | a, rr                 | 1<br>0001 |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | _      | prc        | 2 imm          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 sc          | -     |            | 2 dir                 |           |
| _         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | 2      | JRC        | 4 <b>CP</b>    | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2   | JRZ        | 4 COM         | 2     | JRC        | 4 <b>CP</b>           | 2         |
| 2<br>0010 | е                      | abc             | е                      | b4,rr,ee             | е                     | #         |        | е          | a,(x)          | е                      | abc                  | е                      | b4,rr                 |     | е          | а             |       | е          | a,(y)                 | 0010      |
|           | 1 pcr                  |                 | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1      | prc        | 1 ind          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 inh         | _     | pcr        | 1 ind                 |           |
| 3         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 LD      | 2      | JRC        | 4 CPI          | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 LD          | 2     | JRC        | 4 <b>CP</b>           | 3         |
| 0011      | е                      | abc             | е                      | b4,rr,ee             | е                     | a,x       |        | е          | a,nn           | е                      | abc                  | е                      | b4,rr                 |     | е          | x,a           |       | е          | a, rr                 | 0011      |
|           |                        | 2 ext           |                        | 3 bt                 | 1 pcr                 | 1 sd      | 1      |            | 2 imm          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d.                | 1   | pcr        | 1 sc          | _     | pcr        | 2 dir                 |           |
| 4         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRR</b>         | 2 JRZ                 |           | 2      | JRC        | 4 ADD          | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 RES                 | 2   | JRZ        | 2 <b>RET</b>  | 2     | JRC        | 4 <b>ADD</b>          | 4         |
| 0100      | е                      | abc             | е                      | b2,rr,ee             | е                     | #         |        | е          | a,(x)          | е                      | abc                  | е                      | b2,rr                 |     | е          |               |       | е          | a,(y)                 | 0100      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1      | prc        | 1 ind          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 inh         | -     | pcr        | 1 ind                 |           |
| 5         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 <b>JRS</b>         | 2 JRZ                 | 4 INC     | 2      | JRC        | 4 ADDI         | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 DEC         | 2     | JRC        | 4 <b>ADD</b>          | 5         |
| 0101      | е                      | abc             | е                      | b2,rr,ee             | е                     | У         |        | е          | a,nn           | е                      | abc                  | е                      | b2,rr                 |     | е          | У             |       | е          | a, rr                 | 0101      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1      | prc        | 2 imm          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 sc          | -     | pcr        | 2 dir                 |           |
| 6         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | 2      | JRC        | 4 INC          | 2 JRNZ                 | 4 <b>JP</b>          | 2 JRNC                 | 4 RES                 | 2   | JRZ        | 2 STOP        | 2     |            | 4 INC                 | 6         |
| 0110      | е                      | abc             | e                      | b6,rr,ee             | е                     | #         |        | е          | (x)            | е                      | abc                  | е                      | b6,rr                 |     | е          |               |       | е          | (y)                   | 0110      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 |           | 1      | prc        | 1 ind          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 inh         | _     | pcr        | 1 ind                 |           |
| 7         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 LD      | 2      | JRC        |                | 2 JRNZ                 | -                    | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 LD          | 2     |            | 4 INC                 | 7         |
| 0111      | е                      | abc             | e                      | b6,rr,ee             | e                     | a,y       |        | е          | #              | e                      | abc                  | е                      | b6,rr                 |     | е          | y,a           |       | е          | rr                    | 0111      |
|           | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1      | prc        |                | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 sc          | -     | pcr        | 2 dir                 |           |
| 8         | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 | "         | 2      | JRC        | 4 LD           |                        | 4 JP                 | 2 JRNC                 | 4 RES                 | 2   | JRZ        |               | 2     | JRC        | 4 LD                  | 8         |
| 1000      | e                      | abc             | е                      | b1,rr,ee             | e                     | #         |        | e          | (x),a          | е                      | abc                  | e                      | b1,rr                 |     | е          | #             |       | е          | (y),a                 | 1000      |
|           | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 CALL | 1 pcr<br>2 <b>JRNC</b> | 3 bt<br>5 <b>JRS</b> | 1 pcr<br>2 <b>JRZ</b> | 4 INC     | 1<br>2 | prc<br>JRC | 1 ind          |                        | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 4 050         | 1     | pcr        | 1 ind                 |           |
| 9         |                        | -               |                        |                      | -                     | 4 INC     |        |            | щ              | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 DEC         | 2     | JRC        | 4 LD                  | 9         |
| 1001      | e<br>1 per             | abc<br>2 ext    | e<br>1 pcr             | b1,rr,ee<br>3 bt     | e<br>1 nor            | •         |        | e          | #              | е                      | abc                  | e                      | b1,rr                 |     | е          | V             |       | е          | rr,a<br>2 dir         | 1001      |
|           | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 CALL | 1 pcr<br>2 <b>JRNC</b> | 3 bt<br>5 <b>JRR</b> | 1 pcr<br>2 <b>JRZ</b> | 1 sd      | 2      | prc<br>JRC | 4 AND          | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 <b>JP</b> | 1 pcr<br>2 <b>JRNC</b> | 2 b.d<br>4 <b>RES</b> | 1   | pcr<br>JRZ | 1 sc<br>4 RLC | _     | pcr<br>JRC | 2 dir<br>4 <b>AND</b> |           |
| А         | 2 JRNZ<br>e            | 4 CALL<br>abc   | 2 JKNC<br>e            | b5,rr,ee             | 2 JRZ<br>e            | #         |        | e          | 4 AND<br>a,(x) | -                      | 4 JP<br>abc          | 2 JRNC<br>e            | -                     | 2   | -          |               | 2     |            |                       | A         |
| 1010      | e<br>1 pcr             | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | #         | 1      | prc        | a,(x)<br>1 ind | e<br>1 por             |                      | -                      | b5,rr<br>2 b.d        | 1   | e          | a<br>1 inh    | 1     | e          | a,(y)<br>1 ind        | 1010      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 LD      | 2      | JRC        | 4 ANDI         | 1 pcr<br>2 <b>JRNZ</b> | 2 ext<br>4 <b>JP</b> | 1 pcr<br>2 <b>JRNC</b> | 2 b.d<br>4 <b>SET</b> | 2   | pcr<br>JRZ | 4 LD          | -     | pcr<br>JRC | 4 AND                 |           |
| в         | e                      | abc             | e                      | b5,rr,ee             | e 0112                | a,v       |        | e          | a,nn           | e                      | abc                  | 2 JKNC                 | 4 <b>3∟1</b><br>b5,rr | 2   | e          | + LD<br>v.a   | 12    | e          | a,rr                  | в         |
| 1011      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1      | prc        | 2 imm          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 sc          | 1     | pcr        | 2 dir                 | 1011      |
|           | 2 JRNZ                 |                 | 2 JRNC                 | 5 JRR                | 2 JRZ                 | 1 30      | 2      | JRC        | 4 SUB          | 2 JRNZ                 | 2 ext                | 2 JRNC                 |                       | 2   | JRZ        | 2 RET         | _     | JRC        | 4 SUB                 |           |
| С         | e                      | abc             | e                      | b3,rr,ee             | e                     | #         |        | e          | a,(x)          | e 01112                | abc                  | e                      | b3,rr                 | 2   | e          |               | Ľ     | e          | a,(y)                 | c         |
| 1100      | 1 pcr                  |                 | Ŭ                      | 3 bt                 | 1 pcr                 | "         | 1      | prc        | 1 ind          | 1 pcr                  | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 inh         | 1     | pcr        | 1 ind                 | 1100      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 INC     | 2      | JRC        | 4 SUBI         |                        |                      | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 DEC         | -     |            | 4 SUB                 |           |
| D         | e                      | abc             | e                      | b3.rr.ee             | - •                   | w         | -      | e          | a,nn           | e                      | abc                  | e                      | b3.rr                 | 1   | e          | - DLG         | 1-    | e          | a,rr                  | D         |
| 1101      | 1 pcr                  | 2 ext           | 1 pcr                  | 3 bt                 | 1 pcr                 | 1 sd      | 1      | prc        | 2 imm          | -                      |                      | 1 pcr                  | 2 b.d                 | 1   | pcr        |               | 1     | -          | 2 dir                 | 1101      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRR                | 2 JRZ                 |           | _      | JRC        | 4 DEC          | 2 JRNZ                 |                      | 2 JRNC                 | 4 RES                 | 2   | JRZ        | 2 WAIT        | _     |            | 4 DEC                 |           |
| Е         | e                      | abc             | e                      | b7.rr.ee             | - •                   | #         |        | e          | (x)            | e                      | abc                  | e                      | b7,rr                 | [   | e          |               | 1     | e          | (y)                   | E         |
| 1110      | 1 pcr                  |                 | Ů                      | 3 bt                 | 1 pcr                 |           | 1      | prc        | 1 ind          | -                      | 2 ext                | 1 pcr                  | 2 b.d                 | 1   | pcr        | 1 inh         | 1     | pcr        | 1 ind                 | 1110      |
|           | 2 JRNZ                 | 4 CALL          | 2 JRNC                 | 5 JRS                | 2 JRZ                 | 4 LD      | 2      | JRC        |                | 2 JRNZ                 | 4 JP                 | 2 JRNC                 | 4 SET                 | 2   | JRZ        | 4 LD          | -     | JRC        | 4 DEC                 |           |
| F         | e                      | abc             | e                      | b7,rr,ee             | e                     | a,w       |        | e          | #              | e                      | abc                  | e                      | b7,rr                 | [   | e          | w.a           | 1     | e          | rr                    | F         |
| 1111      | 1 pcr                  |                 | 1 pcr                  |                      | 1 pcr                 |           |        | prc        |                | 1 pcr                  |                      |                        | 2 b.d                 | 1   | pcr        | ,             | 1     | pcr        | 2 dir                 | 1111      |
|           |                        | - 0/1           |                        | - <sup>51</sup>      |                       |           | · ·    | ייק        |                | . por                  | - 0/(                | . por                  | u                     | · . | 201        | . 30          | · · · | 201        |                       |           |

Abbreviations for Addressing Modes: dir Direct

- Short Direct sd Immediate
- imm Inherent inh
- Extended ext
- b.d Bit Direct
- bt Bit Test
- Program Counter Relative Indirect
- pcr ind

| Le | g | er | ٦C |  |
|----|---|----|----|--|
|    |   |    |    |  |

# Indicates Illegal Instructions

5 Bit Displacement

e b 3 Bit Address

1byte dataspace address 1 byte immediate data rr

- nn
- abc 12 bit address
- ee 8 bit Displacement



## **ELECTRICAL CHARACTERISTICS**

#### **Absolute Maximum Ratings**

This product contains devices to protect the inputs against damage due to high static voltages, however it is advised to take normal precaution to avoid application of any voltage higher than maximum rated voltages.

For proper operation it is recommended that  $V_I$  and  $V_O$  must be higher than  $V_{SS}$  and smaller than  $V_{DD}$ . Reliability is enhanced if unused inputs are connected to an appropriated logic voltage level ( $V_{DD}$  or  $V_{SS}$ ). **Power Considerations.**The average chip-junction temperature, Tj, in Celsius can be obtained from:

| Tj =           | T <sub>A</sub> + PD x RthJA |
|----------------|-----------------------------|
| Where $:T_A =$ | Ambient Temperature.        |

RthJA = Package thermal resistance (junction-to ambient).

PD = Pint + Pport.

Pint =  $I_{DD} \times V_{DD}$  (chip internal power).

Pport = Port power dissipation (determinated by the user).

| Symbol           | Parameter                                           | Value                                          | Unit |
|------------------|-----------------------------------------------------|------------------------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                                      | -0.3 to 7.0                                    | V    |
| V <sub>LCD</sub> | Display Voltage                                     | -0.3 to 11.0                                   | V    |
| VI               | Input Voltage                                       | V <sub>SS</sub> - 0.3 to V <sub>DD</sub> + 0.3 | V    |
| Vo               | Output Voltage                                      | $V_{SS}$ - 0.3 to $V_{DD}$ + 0.3               | V    |
| lo               | Current Drain per Pin Excluding $V_{DD}$ & $V_{SS}$ | ± 10                                           | mA   |
| IV <sub>DD</sub> | Total Current into V <sub>DD</sub> (source)         | 50                                             | mA   |
| IVss             | Total Current out of V <sub>SS</sub> (sink)         | 50                                             | mA   |
| Tj               | Junction Temperature                                | 150                                            | °C   |
| T <sub>STG</sub> | Storage Temperature                                 | -60 to 150                                     | °C   |

**Note :** Stresses above those listed as "absolute maximum ratings" may cause permanent damage to the device . This is a stress rating only and functional operation of the device at these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

## THERMAL CHARACTERISTIC

| Symbol | Parameter          | Test Conditions |      | Value | Value |      |  |
|--------|--------------------|-----------------|------|-------|-------|------|--|
| Symbol | i ulunotoi         |                 | Min. | Тур.  | Max.  | Unit |  |
| RthJA  | Thermal Resistance | PQFP52          |      | 70    |       | °C/W |  |

## **RECOMMENDED OPERATING CONDITIONS**

| Symbol           | Parameter                | Test Condition s                     |          | Unit |          |    |  |
|------------------|--------------------------|--------------------------------------|----------|------|----------|----|--|
| Symbol           | i arameter               | rest conditions                      | Min.     | Тур. | Max.     |    |  |
| T <sub>A</sub>   | Operating Temperature    | 1 Suffix Version<br>6 Suffix Version | 0<br>-40 |      | 70<br>85 | °C |  |
| V <sub>DD</sub>  | Operating Supply Voltage |                                      | 3        |      | 6        | V  |  |
| V <sub>LCD</sub> | Display Voltage          |                                      | 3        |      | 10       | V  |  |
| V <sub>DD</sub>  | RAM Retention Voltage    |                                      | 2        |      |          | V  |  |





## RECOMMENDED OPERATING CONDITIONS (Continued)

| Symbol            | Parameter                                                                                       | Test Condition s                     |              | Unit |            |      |
|-------------------|-------------------------------------------------------------------------------------------------|--------------------------------------|--------------|------|------------|------|
| Symbol            | rarameter                                                                                       | rest conditions                      | Min.         | Тур. | Max.       | Onic |
| fosc              | Oscillator Frequency <sup>(1)(4)</sup>                                                          | $V_{DD} \ge 4.5V$<br>$V_{DD} \ge 3V$ | 0.01<br>0.01 |      | 8.388<br>2 | MHz  |
| I <sub>INJ+</sub> | Pin Injection Current (positive)<br>Digital Input <sup>(2)</sup><br>Analog Input <sup>(3)</sup> | $V_{DD}$ = 4.5 to 5.5V               |              |      | +5         | mA   |
| I <sub>INJ-</sub> | Pin Injection Current (negative)<br>Digital Input <sup>(2)</sup><br>Analog Input                | $V_{DD} = 4.5$ to $5.5V$             |              |      | -5         | mA   |

Notes :

An oscillator frequency above 1MHz is recommanded for reliable A/D results.
 A current of ± 5mA can be forced on each pin of the digital section without affecting the functional behaviour of the device. For a positive current injected into one pin, a part of this current (~ 10%) can be expected to flow from the neighbouring pins. A current of -5mA can be forced on one input of the analog section at a time (or -2.5mA for all inputs at a time) without affecting the conversion.
 If a total current of +1mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 1mA, all the conversion is resulting shifted of +1LSB. If a total positive current of +5mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 5mA, all the conversion is resulting shifted of +2LSB.
 Operation below 0.01 MHz is possible but requires increased supply current.

## **EEPROM INFORMATION**

The ST62xx EEPROM single poly process has been specially developed to achieve 300.000 Write/Erase cycles and a 10 years data retention.

## DC ELECTRICAL CHARACTERISTICS

(T<sub>A</sub> = -40 to +85°C unless otherwise specified)

| Symbol          | Parameter                 | Test Conditions                                                                                                                                                                                                                                             |                     | Value |                    | Unit           |
|-----------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------|--------------------|----------------|
| Symbol          |                           | Test conditions                                                                                                                                                                                                                                             | Min.                | Тур.  | Max.               | onit           |
| VIL             | Input Low Level Voltage   | RESET, NMI, TIMER,<br>WDON Pin                                                                                                                                                                                                                              |                     |       | 0.3V <sub>DD</sub> | V              |
|                 |                           | TIMER                                                                                                                                                                                                                                                       | 0.80V <sub>DD</sub> |       |                    | V              |
| VIH             | Input High Level Voltage  | RESET, NMI,<br>WDON Pin                                                                                                                                                                                                                                     | 0.70V <sub>DD</sub> |       |                    | V              |
| Іц<br>Ін        | Input Leakage Current     | $\begin{array}{l} \text{RESET Pin} \\ \text{V}_{\text{DD}} = 5\text{V} \\ \text{V}_{\text{IN}} = \text{V}_{\text{DD}} \ ^{(1)} \\ \text{V}_{\text{IN}} = \text{V}_{\text{DD}} \ ^{(2)} \\ \text{V}_{\text{IN}} = \text{V}_{\text{SS}} \ ^{(5)} \end{array}$ |                     |       | 10<br>1<br>50      | μA<br>mA<br>μA |
| V <sub>OL</sub> | Low Level Output Voltage  | TIMER, $I_{OL} = 5.0 \text{mA}$                                                                                                                                                                                                                             |                     |       | 0.2V <sub>DD</sub> | v              |
| V <sub>OH</sub> | High Level Output Voltage | TIMER, I <sub>OL</sub> = -5.0mA                                                                                                                                                                                                                             | 0.65V <sub>DD</sub> |       |                    | V              |
| R <sub>PU</sub> | Pull-up Resistor          | V <sub>IN</sub> =0V V <sub>DD</sub> =5V<br>WDON - NMI                                                                                                                                                                                                       | 40                  | 100   | 200                | kΩ             |
|                 |                           | RESET                                                                                                                                                                                                                                                       | 200                 | 300   | 500                | kΩ             |

Notes on next page



# DC ELECTRICAL CHARACTERISTICS (Continued) $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$

| Symbol                | Parameter                       | Test Conditions                                          |      | Value |            | Unit |
|-----------------------|---------------------------------|----------------------------------------------------------|------|-------|------------|------|
| Gymbol                | i didilietei                    | Test conditions                                          | Min. | Тур.  | Max.       | Onic |
| I <sub>IL</sub><br>Iн | Input Leakage Current           | TIMER<br>Vin = Vdd or Vss                                |      | 0.1   | 1.0        | μA   |
| ILL<br>IH             | Input Leakage Current           |                                                          |      |       | 100<br>1.0 | μΑ   |
| Іц<br>Іін             | Input Leakage Current           | $WDON VDD = 5V V_{IN} = V_{SS} (5) V_{IN} = V_{DD}$      |      |       | 100<br>1.0 | μΑ   |
|                       | Supply Current RUN Mode         | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$ |      | 4     | 7          | mA   |
| ldd                   | Supply Current WAIT Mode (4)    | $f_{OSC} = 8MHz,$<br>$I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$ |      | 1     | 2          | mA   |
|                       | Supply Current RESET Mode       | fosc = 8MHz,<br>Vreset = Vss                             |      | 1     | 7          | mA   |
|                       | Supply Current STOP Mode (3)(4) | $I_{LOAD} = 0mA$<br>$V_{DD} = 5.0V$                      |      | 1     | 10         | μΑ   |

 Notes :

 1. No Watchdog Reset activated.

 2. Reset generated by Watchdog.

 3. When the watchdog function is actvated the STOP instruction is deactivated. WAIT instruction is automatically executed.

 4. All on-chip peripherals in OFF state

 5. Pull-up resistor



## CURRENT CONSUMPTION





## AC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                           | Test Condition s                                                    |         | Unit           |            |        |
|------------------|-------------------------------------|---------------------------------------------------------------------|---------|----------------|------------|--------|
| Cymbol           |                                     |                                                                     | Min.    | Тур.           | Max.       |        |
| fosc             | Oscillator Frequency <sup>(2)</sup> | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01    |                | 8.388<br>2 | MHz    |
| ts∪              | Oscillator Start-up Time            | $C_{L1} = C_{L2} = 22pF - crystal$                                  |         | 5              | 20         |        |
| t <sub>SR</sub>  | Supply Rise Time                    | 10% to 90%                                                          | 0.01    | 0.01 100       |            | ms     |
| t <sub>REC</sub> | Supply Recovery Time <sup>(1)</sup> |                                                                     | 100     |                |            |        |
| Tw               | Minimum Pulse Width                 | NMI Pin<br>V <sub>DD</sub> = 5V                                     | 100     |                |            | ns     |
|                  |                                     | RESET Pin                                                           | 100     |                |            | ns     |
| T <sub>WEE</sub> | EEPROM Write Time                   | $T_A = 25^{\circ}C$ One Byte<br>$T_A = 85^{\circ}C$ One Byte        |         | 5<br>15        | 10<br>25   | ms     |
| Endurance        | EEPROM WRITE/ERASE<br>Cycles        | Q <sub>A</sub> L <sub>OT</sub><br>Acceptance Criteria               | 300.000 | > 1<br>million |            | cycles |
| Retention        | EEPROM Data Retention               | $T_A = 55^{\circ}C$                                                 | 10      |                |            | years  |
| CIN              | Input Capacitance                   | All Inputs Pins                                                     |         |                | 10         | pF     |
| Соит             | Output Capacitance                  | All Outputs Pins                                                    |         |                | 10         | pF     |

Notes:

Period for which V<sub>DD</sub> has to be connected or at 0V to allow internal Reset function at next power-up.
 Operation below 0.01 MHz is possible but requires increased supply current.





## **I/O PORTS**

 $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwhise specified})$ 

| Symbol          | Parameter                                 | Test Condition s                                                 |                      | Unit |                                 |      |
|-----------------|-------------------------------------------|------------------------------------------------------------------|----------------------|------|---------------------------------|------|
| Symbol          | Farameter                                 | Test Condition's                                                 | Min.                 | Тур. | Max.                            | Onit |
| V <sub>IL</sub> | Input Low Level Voltage                   | I/O Pins                                                         |                      |      | 0.3V <sub>DD</sub>              | V    |
| VIH             | Input High Level Voltage                  | I/O Pins                                                         | $0.7V_{DD}$          |      |                                 | V    |
|                 |                                           | I/O Pins,<br>I <sub>O</sub> = 10μA (sink)                        |                      |      | 0.1                             | V    |
|                 | Low Level Output Voltage                  | I/O Pins, $I_{OL} = V_{DD}x1mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |      | 0.16xV <sub>DD</sub>            | V    |
|                 |                                           | $I/O$ Pins, $I_{OL} = 1.6mA$<br>$V_{DD} = 3V$                    |                      |      | 0.4 V<br>0.16xV <sub>DD</sub> V | V    |
| V <sub>OL</sub> | Low Level Output Voltage,<br>PB4-PB7 Only | I/O Pins, $I_{OL} = V_{DD}x2mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |      | 0.16xV <sub>DD</sub>            | V    |
|                 |                                           | I/O Pins, $I_{OL}$ = 3.2mA<br>V <sub>DD</sub> = 3V               |                      |      | 0.4                             | V    |
|                 |                                           | I/O Pins, $I_{OL} = V_{DD}x4mA$<br>$V_{DD} = 4.5 \text{ to } 6V$ |                      |      | 0.26xV <sub>DD</sub>            | V    |
|                 |                                           | I/O Pins, $I_{OL} = 6.4mA$<br>$V_{DD} = 3V$                      |                      |      | 0.8                             | V    |
| V <sub>он</sub> | High Level Output Voltage                 | I/O Pins,<br>I <sub>O</sub> = -10μA (source)                     | V <sub>DD</sub> -0.1 |      |                                 | V    |
| ⊻ОН             |                                           | I/O Pins, $I_{OL} = -V_{DD}x1mA$<br>$V_{DD} = 5.0V$              | 0.6xV <sub>DD</sub>  |      |                                 | V    |
| I∟<br>Ін        | Input Leakage Current                     | I/O Pins, <sup>(1)</sup>                                         |                      | 0.1  | 1.0                             | μΑ   |
| R <sub>PU</sub> | Pull-up Resistor                          | I/O Pins<br>V <sub>IN</sub> = 0V, V <sub>DD</sub> = 5.0V         | 40                   | 100  | 200                             | KΩ   |

Note 1. Pull-up resistor off

## SPI ELECTRICAL CHARACTERISTICS

 $(V_{DD} = 5.0V, T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwhise specified})$ 

| Symbol         | Parameter       | Test Conditions    | Value |      |      | Unit |
|----------------|-----------------|--------------------|-------|------|------|------|
| Gymbol         | i didiliciti    |                    | Min.  | Тур. | Max. | onit |
| Fc∟            | Clock Frequency | applied on PB5/SCL |       |      | 1    | MHz  |
| ts∪            | Set-up Time     | applied on PB6/Sin |       | 50   |      | ns   |
| t <sub>h</sub> | Hold Time       | applied on PB6/Sin |       | 100  |      | ns   |



## A/D CONVERTER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                          | Parameter                                 | Test Conditions                                        | Value    |      |                 | Unit |
|---------------------------------|-------------------------------------------|--------------------------------------------------------|----------|------|-----------------|------|
| Gymbol                          |                                           |                                                        | Min.     | Тур. | Max.            | onit |
| Res                             | Resolution (3)                            |                                                        |          | 8    |                 | Bit  |
| A <sub>TOT</sub>                | Total Accuracy (3)                        | f <sub>OSC</sub> > 1.2 MHz<br>f <sub>OSC</sub> > 32kHz |          |      | ± 2<br>±4       | LSB  |
| tc <sup>(1)</sup>               | Conversion Time                           | f <sub>OSC</sub> = 8MHz                                |          | 70   |                 | μs   |
| V <sub>AN</sub>                 | Conversion Range                          |                                                        | $V_{SS}$ |      | V <sub>DD</sub> | V    |
| ZIR                             | Zero Input Reading                        | Conversion result when $V_{IN} = V_{SS}$               | 00       |      |                 | Hex  |
| FSR                             | Full Scale Reading                        | Conversion result when $V_{IN} = V_{DD}$               |          |      | FF              | Hex  |
| ADI                             | Analog Input Current During<br>Conversion | V <sub>DD</sub> = 4.5V                                 |          |      | 1.0             | μΑ   |
| AC <sub>IN</sub> <sup>(2)</sup> | Analog Input Capacitance                  |                                                        |          | 2    | 5               | pF   |
| ASI                             | Analog Source Impedance                   |                                                        |          |      | 30              | kΩ   |
| SSI                             | Analog Reference Supply<br>Impedence      |                                                        |          |      | 2               | kΩ   |

Notes:
1. With oscillator frequencies less than 1MHz, the A/D Converter accuracy is decreased.
2. Excluding Pad Capacitance
3. Noise at V<sub>DD</sub>,V<sub>SS</sub> ≤ 10mV



## TIMER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                    | Test Conditions                      | Value                |      |                     | Unit     |
|------------------|------------------------------|--------------------------------------|----------------------|------|---------------------|----------|
| Symbol           |                              |                                      | Min.                 | Тур. | Max.                |          |
| t <sub>RES</sub> | Resolution                   |                                      | $\frac{12}{f_{OSC}}$ |      |                     | second   |
| f <sub>IN</sub>  | Input Frequency on TIMER Pin |                                      |                      |      | $\frac{f_{OSC}}{8}$ | MHz      |
| tw               | Pulse Width at TIMER Pin     | $V_{DD} \ge 3V$<br>$V_{DD} \ge 4.5V$ | 1<br>125             |      |                     | μs<br>ns |

#### LCD ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                        | Test Conditions                              | Value |      |      | Unit |
|------------------|----------------------------------|----------------------------------------------|-------|------|------|------|
| Symbol           | i arameter                       | resconditions                                | Min.  | Тур. | Max. | onic |
| ffr              | Frame Frequency                  | 1/4 Duty<br>f <sub>OSC</sub> = 1, 2, 4, 8MHz | 16    |      | 128  | Hz   |
| Vos              | DC Offset Voltage <sup>(1)</sup> | $V_{LCD} = V_{DD}$ , no load                 |       |      | 50   | mV   |
| V <sub>OH</sub>  | COM High Level, Output Voltage   | $I=100\mu A, V_{LCD}=5V$                     | 4.5V  |      |      | V    |
| Vol              | COM Low Level, Output Voltage    | $I=100\mu A,\ V_{LCD}=5V$                    |       |      | 0.5V | V    |
| V <sub>OH</sub>  | SEG High Level, Output Voltage   | $I = 50 \mu A, V_{LCD} = 5 V$                | 4.5V  |      |      | V    |
| Vol              | SEG Low Level, Output Voltage    | $I = 50\mu A$ , $V_{LCD} = 5V$               |       |      | 0.5V | V    |
| V <sub>LCD</sub> | Display Voltage                  | Note 2                                       | 3     |      | 10   | V    |

Notes :

1. The DC offset voltage refers to all segment and common outputs. It is the difference between the measured voltage value and nominal value for every voltage level. Ri of voltage meter must be greater than or equal to  $100M\Omega$ . 2. An external resistances network is required when V<sub>LCD</sub>  $\leq$  4.5V.



## ST6245

## PACKAGE MECHANICAL DATA

## Figure 50. ST6245 52 Pin Plastic Quad Flat Pack Package





## PACKAGE MECHANICAL DATA (Continued)

## Recommanded Solder Pad Footprint For QFP52 (in mm)





#### **ORDERING INFORMATION**

The following chapter deals with the procedure for transfer the Program/Data ROM codes to SGS-THOMSON.

**Communication of the ROM Codes.** To communicate the contents of Program/Data ROM memories to SGS-THOMSON, the customer has to send :

- one file in INTEL INTELLEC 8/MDS FORMAT (in an MS-DOS 5" diskette) for the PROGRAM Memory
- one file in INTEL INTELLEC 8/MDS FORMAT (in a MS-DOS 5" diskette) for the EEPROM initial content (this file is optional)
- a filled Option List form as described in the OPTION LIST paragraph.

The program ROM should respect the ROM Memory Map as in Table 20.

The ROM code must be generated with ST6 assembler. Before programming the EPROM, the buffer of the EPROM programmer must be filled with FFh.

| ROM Page           | Device Address                                                                         | Description                                                                         |
|--------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|
| Page 0             | 0000h-007Fh<br>0080h-07FFh                                                             | Reserved<br>User ROM                                                                |
| Page 1<br>"STATIC" | 0800h-0F9Fh<br>0FA0h-0FEFh<br>0FF0h-0FF7h<br>0FF8h-0FFBh<br>0FFCh-0FFDh<br>0FFEh-0FFFh | User ROM<br>Reserved<br>Interrupt Vectors<br>Reserved<br>NMI Vector<br>Reset Vector |

Table 20. ROM Memory Map

Note : EPROM addresses are related to the ROM file to be processed.

#### Customer EEPROM Initial Contents : Format

a. The content should be written into an INTEL INTELLEC format file.

b. In the case of 128 bytes of EEPROM, the starting address in 000h and the end in 7Fh.

c. Undefined or don't care bytes should have the content FFh.

Listing Generation & Verification. When SGS-THOMSON receives the Codes, they are compared and a computer listing is generated from them. This listing refers exactly to the mask that will be used to produce the microcontroller. Then the listing is returned to the customer that must thoroughly check, complete, sign and return it to SGS-THOMSON. The signed list constitutes a part of the contractual agreement for the creation of the customer mask. SGS-THOMSON sales organization will provide detailed information on contractual points.

#### **ORDERING INFORMATION TABLE**

| Sales Types | Memory Type               | Temperature Range | Package |
|-------------|---------------------------|-------------------|---------|
| ST6245Q1/XX | 4K ROM<br>64 bytes EEPROM | 0 to + 70°C       | PQFP52  |
| ST6245Q6/XX | 4K ROM<br>64 bytes EEPROM | -40 to + 85°C     | PQFP52  |

Note : "XX" is the ROM code identifier allocated by SGS-THOMSON after receipt of all required options and the related ROM file.



| ST6245 MICROCONTROLLER OPTIO                                                                                                           | N LIST          |
|----------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| Customer                                                                                                                               |                 |
| Address                                                                                                                                |                 |
| Contact                                                                                                                                |                 |
| Phone No                                                                                                                               |                 |
| Reference                                                                                                                              |                 |
|                                                                                                                                        |                 |
| SGS-THOMSON Microelectronics references                                                                                                |                 |
| Device []ST6245                                                                                                                        |                 |
| Package[ ] Plastic Quad Flat PackageTemperature Range[ ] 0°C to + 70°C[ ]                                                              | -40°C to + 85°C |
| Special Marking [ ] No<br>[ ] Yes ""                                                                                                   |                 |
| Authorized characters are Letters, digits, '.', '-', '/' and spaces on<br>For marking one line with 10 characters maximum is possible. | у.              |
| Comments :                                                                                                                             |                 |
| - Number of LCD segments used :<br>- Number of LCD backplanes used :                                                                   |                 |
| Note :                                                                                                                                 |                 |
|                                                                                                                                        |                 |
|                                                                                                                                        |                 |
| Signature                                                                                                                              |                 |
| Date                                                                                                                                   |                 |
|                                                                                                                                        |                 |



ST6245

NOTES:





# ST62E45 ST62T45

# 8-BIT OTP/EPROM HCMOS MCUs WITH LCD DRIVER,EEPROM AND A/D CONVERTER

- 3 to 6V supply operating range
- 8.4MHz Maximum Clock Frequency
- Run, Wait & Stop Modes
- 5 different interrupt vectors
- Look-up table capability in EPROM

| User EPROM: | 3884 bytes |
|-------------|------------|
| Data RAM:   | 128 bytes  |
| LCD RAM:    | 12 bytes   |
| EEPROM:     | 64 bytes   |

- PQFP52 and CQFP52-W packages
- 11 fully software programmable I/O as:
  - Input with/without pull-up resistor
  - Input with interrupt generation
  - Open-Drain or Push-pull outputs
  - Analog Inputs (7 pins)
- 4 I/O lines can sink up to 20mA for direct LED or TRIAC driving and have SPI alternate functions
- Two 8-bit counters and 7-bit programmable prescalers (Timers 1 and 2)
- Software activated digital watchdog
- 8-bit A/D converter with up to 7 analog inputs
- 8-bit synchronous serial peripheral interface (SPI)
- LCD driver with 24 segment outputs, 4 backplane outputs and selectable duty cycle for up to 96 LCD segments direct driving
- 32kHz oscillator for stand-by LCD operation
- One external not maskable interrupt
- 9 powerful addressing modes
- The accumulator, the X, Y, V & W registers, the port and peripherals data & control registers are addressed in the data space as RAM locations.
- The ST62E45 is the EPROM version, ST62T45 is the OTP version, fully compatible with ST6245 ROM version.



# ST62E45 - ST62T45



# Figure 1. 52 Pin Quad Flat Pack (QFP) Package Pinout

# ST62E45/T45 Pin Description

| Pin    | Pin             | Pin    | Pin                     | Pin    | Pin      | Pin    | Pin  |
|--------|-----------------|--------|-------------------------|--------|----------|--------|------|
| number | name            | number | name                    | number | name     | number | name |
| 1      | COM4            | 14     | RESET                   | 27     | OSC32out | 40     | S28  |
| 2      | COM3            | 15     | OSCout                  | 28     | OSC32in  | 41     | S29  |
| 3      | COM2            | 16     | OSCin                   | 29     | S17      | 42     | S30  |
| 4      | COM1            | 17     | NMI                     | 30     | S18      | 43     | S31  |
| 5      | VLCD1/3         | 18     | TIMER                   | 31     | S19      | 44     | S32  |
| 6      | VLCD2/3         | 19     | PB7/Sout <sup>(1)</sup> | 32     | S20      | 45     | S33  |
| 7      | VLCD            | 20     | PB6/Sin <sup>(1)</sup>  | 33     | S21      | 46     | S34  |
| 8      | PA7/Ain         | 21     | PB5/SCL <sup>(1)</sup>  | 34     | S22      | 47     | S35  |
| 9      | PA6/Ain         | 22     | PB4 <sup>(1)</sup>      | 35     | S23      | 48     | S36  |
| 10     | PA5/Ain         | 23     | PB3/Ain                 | 36     | S24      | 49     | S37  |
| 11     | TEST            | 24     | PB2/Ain                 | 37     | S25      | 50     | S38  |
| 12     | V <sub>DD</sub> | 25     | PB1/Ain                 | 38     | S26      | 51     | S39  |
| 13     | V <sub>SS</sub> | 26     | PB0/Ain                 | 39     | S27      | 52     | S40  |

Note 1: 20mA SINK



#### **GENERAL DESCRIPTION**

The ST62E45,T45 microcontrollers are members of the 8-bit HCMOS ST62xx family, a series of devices oriented to low-medium complexity applications. They are the EPROM/OTP versions of the ST6245 ROM device and are suitable for product prototyping and low volume production. All ST62xx members are based on a building block approach: a common core is associated with a combination of on-chip peripherals (macrocells). The macrocells of the ST6245 family are: a high performance LCD controller/driver with 24 segment outputs and 4 backplanes able to drive up to 96 segments, two Timer peripherals each including an 8-bit counter with a 7-bit software programmable prescaler (Timer), the digital watchdog timer (DWD), an 8-bit A/D Converter with up to 7 analog inputs and an 8-bit synchronous Serial Peripheral Interface (SPI). In addition these devices offer 64 bytes of EEPROM for storage of non volatile data. Thanks to these peripherals the ST6245 family is well suited for general purpose, automotive, security, appliance and industrial applications.



Figure 2. ST62E45 Block Diagram

Note  $^{(1)}$ : VPP only exists in EPROM version



#### PIN DESCRIPTION

 $V_{DD}$  and  $V_{SS}.$  Power is supplied to the MCU using these two pins.  $V_{DD}$  is power and  $V_{SS}$  is the ground connection.

**OSCin and OSCout**. These pins are internally connected with the on-chip oscillator circuit. A quartz crystal or a ceramic resonator can be connected between these two pins in order to allow the correct operation of the MCU with various stability/cost trade-offs. OSCin is the input pin, OSCout is the output pin. An external clock signal can be applied to OSCin.

**RESET.** The active low **RESET** pin is used to restart the microcontroller at the beginning of its program. The **RESET** pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TEST/VPP.** The TEST must be held at V<sub>SS</sub> for normal operation (an internal pull-down resistor selects normal operating mode if TEST pin is not connected).

**NMI.** The NMI pin provides the capability for asynchronous applying an external top priority interrupt to the MCU. This pin is falling edge sensitive. The NMI pin is provided with an on-chip pull-up resistor and schmitt trigger input characteristics.

**TIMER.** This is the TIMER 1 I/O pin. In input mode it is connected to the prescaler and acts as external timer clock or as control gate for the internal timer clock. In the output mode the TIMER pin outputs the data bit when a time-out occurs.

**PA5-PA7.** These 3 lines are organized as one I/O port (A). Each line may be configured under software control as an input with or without pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output or as analog input for the A/D converter. Port A has a 5mA drive capability in output mode.

**PB0-PB3,PB4-PB7.** These 8 lines are organized as one I/O port (B). Each line may be configured under software control as an input with or without internal pull-up resistor, interrupt generating input with pull-up resistor, open-drain or push-pull output. PB0-PB3 can be programmed as analog inputs for the A/D converter while PB4-PB7 can also sink 20mA for direct LED driving. PB5-PB7 can also be used as respectively Clock, Data in and Data out pins for the on-chip SPI to carry the synchronous serial I/O signals.

**COM1-COM4.** These four pins are the LCD peripheral common outputs. They are the outputs of the on-chip backplane voltage generator which is used for multiplexing the 24 LCD lines allowing up to 96 segments to be driven.

**S17-S40.** These pins are the 24 LCD peripheral driver outputs of ST62E45. Segments S1-S16 and S41-S48 are not connected to any pin.

**VLCD.** Display voltage supply. It determines the high voltage level on COM1-COM4 and S1-S24 pins.

VLCD1/3, VLCD2/3. Display supply voltage inputs for determining the display voltage levels on COM1-COM4 and S1-S24 pins during multiplex operation.

**OSC32in and OSC32out.** These pins are internally connected with the on-chip 32kHz oscillator circuit. A 32.768kHz quartz crystal can be connected between these two pins if it is necessary to provide the LCD stand-by clock and real time interrupt. OSC32in is the input pin, OSC32out is the output pin.



#### ST62E45, T45 EPROM/OTP DESCRIPTION

The ST62E45 is the EPROM version of the ST6245 ROM product. It is intended for use during the development of an application, and for pre-production and small volume production. The ST62T45 OTP has the same characteristics. Both include EPROM memory instead of the ROM memory of the ST6245, and so the program and constants of the program can be easily modified by the user with the ST62E45 EPROM programming board from SGS-THOMSON.

From a user point of view (with the following exception) the ST62E45,T45 products have exactly the same software and hardware features of the ROM version. An additional mode is used to configure the part for programming of the EPROM, this is set by a +12.5V voltage applied to the TEST/V<sub>PP</sub> pin. The programming of the ST62E45,T45 is described in the User Manual of the EPROM Programming board.

On the ST62E45, all the 3884 bytes of PROGRAM memory are available for the user, as all the EPROM memory can be erased by exposure to UV light. On the ST62T45 (OTP) device) a reserved area for test purposes exists, as for the ST6245 ROM device. In order to avoid any discrepancy between program functionality when using the EPROM, OTP and ROM it is recommended not to use these reserved areas, even when using the ST62E45.

#### Notes on programming:

In order to emulate exactly the ST6245 features with the ST62E45 and ST6245, some software precautions have to be taken:

1. I/O: To prevent floating input or uncontrolled I/O interrrupt on the EPROM/OTP devices, the port bits PA0-PA4 must be programmed as push-pull outputs.

2. When programming for the EPROM/OTP parts, it is suggested that the conditional assembly technique is used for controlling the I/O ports in order to disable the appropriate code for the ROM device.

3. Do not access data space locations CAh, DAh.

Other than this exception, the ST62E45,T45 parts are fully compatible with the ROM ST6245 equivalent, this datasheet thus provides only information specific to the EPROM based devices.

#### THE READER IS ASKED TO REFER TO THE DATASHEET OF THE ST6240 ROM-BASED DE-VICE FOR FURTHER DETAILS.

#### **EPROM ERASING**

The EPROM of the windowed package of the ST62E45 may be erased by exposure to Ultra Violet light.

The erasure characteristic of the ST62E45 EPROM is such that erasure begins when the memory is exposed to light with wave lengths shorter than approximately 4000Å. It should be noted that sunlight and some types of fluorescent lamps have wavelengths in the range 3000-4000Å. It is thus recommended that the window of the ST62E45 package be covered by an opaque label to prevent unintentional erasure problems when testing the application in such an environment.

The recommended erasure procedure of the ST62E45 EPROM is exposure to short wave ultraviolet light which has wavelength 2537Å. The integrated dose (i.e. UV intensity x exposure time) for erasure should be a minimum of 15 W-sec/cm<sup>2</sup>. The erasure time with this dosage is approximately 15 to 20 minutes using an ultraviolet lamp with 12000 $\mu$ W/cm<sup>2</sup> power rating. The ST62E45 should be placed within 2.5 cm (1 inch) of the lamp tubes during erasure.



#### **ELECTRICAL CHARACTERISTICS**

#### **Absolute Maximum Ratings**

This product contains devices to protect the inputs against damage due to high static voltages, however it is advised to take normal precaution to avoid application of any voltage higher than maximum rated voltages.

For proper operation it is recommended that  $V_l$  and  $V_O$  must be higher than  $V_{SS}$  and smaller than  $V_{DD}$ . Reliability is enhanced if unused inputs are connected to an appropriated logic voltage level ( $V_{DD}$  or  $V_{SS}$ ). **Power Considerations.**The average chip-junction temperature, Tj, in Celsius can be obtained from:

| Tj =                 | T <sub>A</sub> + PD x RthJA                                  |
|----------------------|--------------------------------------------------------------|
| Where: . $T_A=\ .$ . | Ambient Temperature.                                         |
|                      | Package thermal resistance (junction-to ambient).            |
| PD = .               | Pint + Pport.                                                |
| Pint = .             | $I_{\text{DD}} \; x \; V_{\text{DD}}$ (chip internal power). |
|                      | Port power dissipation (determinated by the user).           |

| Symbol           | Parameter                                   | Value                                          | Unit |
|------------------|---------------------------------------------|------------------------------------------------|------|
| V <sub>DD</sub>  | Supply Voltage                              | -0.3 to 7.0                                    | V    |
| V <sub>LCD</sub> | Display Voltage                             | -0.3 to 11.0                                   | V    |
| VI               | Input Voltage                               | $V_{SS}$ - 0.3 to $V_{DD}$ + 0.3               | V    |
| Vo               | Output Voltage                              | $V_{\text{SS}}$ - 0.3 to $V_{\text{DD}}$ + 0.3 | V    |
| lo               | Current Drain per Pin Excluding VDD & VSS   | ± 10                                           | mA   |
| IV <sub>DD</sub> | Total Current into V <sub>DD</sub> (source) | 50                                             | mA   |
| IVss             | Total Current out of V <sub>SS</sub> (sink) | 50                                             | mA   |
| Tj               | Junction Temperature                        | 150                                            | °C   |
| T <sub>STG</sub> | Storage Temperature                         | -60 to 150                                     | °C   |

Note : Stresses above those listed as "absolute maximum ratings" may cause permanent damage to the device . This is a stress rating only and functional operation of the device at these conditions is not implied. Exposure to maximum rating conditions for extended periods may affect device reliability.

## THERMAL CHARACTERISTIC

| Symbol | Parameter          | Test Conditions    | Value |          |      | Unit |
|--------|--------------------|--------------------|-------|----------|------|------|
| Symbol |                    |                    | Min.  | Тур.     | Max. | Onit |
| RthJA  | Thermal Resistance | PQFP52<br>CQFP52-W |       | 70<br>70 |      | °C/W |

#### **RECOMMENDED OPERATING CONDITIONS**

| Symbol           | Parameter                | Test Condition s                     |          | Unit |          |     |
|------------------|--------------------------|--------------------------------------|----------|------|----------|-----|
| Symbol           |                          |                                      | Min.     | Тур. | Max.     | onn |
| T <sub>A</sub>   | Operating Temperature    | 1 Suffix Version<br>6 Suffix Version | 0<br>-40 |      | 70<br>85 | °C  |
| V <sub>DD</sub>  | Operating Supply Voltage |                                      | 3        |      | 6        | V   |
| V <sub>LCD</sub> | Display Voltage          |                                      | 3        |      | 10       | V   |
| V <sub>RM</sub>  | RAM Retention Voltage    |                                      | 2        |      |          | V   |



# RECOMMENDED OPERATING CONDITIONS (Continued)

| Symbol            | Parameter                                                                                       | Test Condition s                     |              | Unit |            |      |
|-------------------|-------------------------------------------------------------------------------------------------|--------------------------------------|--------------|------|------------|------|
| Symbol            | i arameter                                                                                      | rest conditions                      | Min.         | Тур. | Max.       | onit |
| fosc              | Oscillator Frequency <sup>(1)(4)</sup>                                                          | $V_{DD} \ge 4.5V$<br>$V_{DD} \ge 3V$ | 0.01<br>0.01 |      | 8.388<br>2 | MHz  |
| I <sub>INJ+</sub> | Pin Injection Current (positive)<br>Digital Input <sup>(2)</sup><br>Analog Input <sup>(3)</sup> | V <sub>DD</sub> = 4.5 to 5.5V        |              |      | +5         | mA   |
| I <sub>INJ-</sub> | Pin Injection Current (negative)<br>Digital Input <sup>(2)</sup><br>Analog Input                | V <sub>DD</sub> = 4.5 to 5.5V        |              |      | -5         | mA   |

Notes :

1. An oscillator frequency above 1MHz is recommanded for reliable A/D results.

2. A current of ± 5mA can be forced on each pin of the digital section without affecting the functional behaviour of the device. For a positive current injected into one pin, a part of this current (~ 10%) can be expected to flow from the neighbouring pins. A current of -5mA can be forced on one input of the analog section at a time (or -2.5mA for all inputs at a time) without affecting the conversion.

3. If a total current of +1mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 1mA, all the conversion is resulting shifted of +1LSB. If a total positive current of +5mA is flowing into the single analog channel or if the total current flowing into all the analog inputs is of 5mA, all the conversion is resulting shifted of +2LSB.

4. Operation below 0.01 MHz is possible but requires increased supply current.

# **EEPROM INFORMATION**

The ST62xx EEPROM single poly process has been specially developed to achieve 300.000 Write/Erase cycles and a 10 years data retention.

#### DC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                                   | Parameter                 | Test Conditions                 |                     | Unit |                    |                |
|------------------------------------------|---------------------------|---------------------------------|---------------------|------|--------------------|----------------|
| Gymbol                                   | rarameter                 |                                 | Min.                | Тур. | Max.               | onit           |
| V <sub>IL</sub>                          | Input Low Level Voltage   | RESET, NMI, TIMER,<br>WDON Pin  |                     |      | 0.3V <sub>DD</sub> | v              |
|                                          |                           | TIMER                           | 0.80V <sub>DD</sub> |      |                    | V              |
| V <sub>IH</sub> Input High Level Voltage | Input High Level Voltage  | RESET, NMI,<br>WDON Pin         | 0.70V <sub>DD</sub> |      |                    | V              |
| I <sub>IL</sub><br>IIH                   | Input Leakage Current     |                                 |                     |      | 10<br>1<br>50      | μA<br>mA<br>μA |
| V <sub>OL</sub>                          | Low Level Output Voltage  | TIMER, I <sub>OL</sub> = 5.0mA  |                     |      | 0.2V <sub>DD</sub> | V              |
| V <sub>OH</sub>                          | High Level Output Voltage | TIMER, I <sub>OL</sub> = -5.0mA | 0.65V <sub>DD</sub> |      |                    | V              |

Notes on next page



# **DC ELECTRICAL CHARACTERISTICS** (Continued) $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwise specified})$

| Symbol                             | Parameter                                  | Test Conditions                                                  |      | Value |            | Unit |
|------------------------------------|--------------------------------------------|------------------------------------------------------------------|------|-------|------------|------|
| Symbol                             |                                            |                                                                  | Min. | Тур.  | Max.       |      |
| R <sub>PU</sub>                    | Pull-up Resistor                           | Vin=0V Vdd=5V<br>WDON - NMI                                      | 40   | 100   | 200        | kΩ   |
|                                    |                                            | RESET                                                            | 100  | 300   | 500        | kΩ   |
| I <sub>IL</sub><br>I <sub>IH</sub> | Input Leakage Current                      | TIMER<br>V <sub>IN</sub> = V <sub>DD</sub> or V <sub>SS</sub>    |      | 0.1   | 1.0        | μΑ   |
| I <sub>IL</sub><br>I <sub>IH</sub> | Input Leakage Current                      |                                                                  |      |       | 100<br>1.0 | μΑ   |
| lıL<br>lıH                         | Input Leakage Current                      |                                                                  |      |       | 100<br>1.0 | μΑ   |
|                                    | Supply Current RUN Mode                    |                                                                  |      | 4     | 7          | mA   |
| I <sub>DD</sub>                    | Supply Current WAIT Mode <sup>(4)</sup>    |                                                                  |      | 1     | 2          | mA   |
|                                    | Supply Current RESET Mode                  | f <sub>OSC</sub> = 8MHz,<br>V <sub>RESET</sub> = V <sub>SS</sub> |      | 1     | 7          | mA   |
|                                    | Supply Current STOP Mode <sup>(3)(4)</sup> | I <sub>LOAD</sub> = 0mA<br>V <sub>DD</sub> = 5.0V                |      | 1     | 10         | μΑ   |

Notes :

1. No Watchdog Reset activated.

2. Reset generated by Watchdog.

3. When the watchdog function is activated the STOP instruction is deactivated. WAIT instruction is automatically executed.

4. All on-chipperipherals in OFF state

5. Pull-up resistor



# AC ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                    | Test Condition s                                                    |              | Value          |            |          |  |
|------------------|------------------------------|---------------------------------------------------------------------|--------------|----------------|------------|----------|--|
| Symbol           | Farameter                    | rest conditions                                                     | Min.         | Тур.           | Max.       | Unit     |  |
| fosc             | Oscillator Frequency (2)     | $\begin{array}{l} V_{DD} \geq 4.5 V \\ V_{DD} \geq 3 V \end{array}$ | 0.01<br>0.01 |                | 8.388<br>2 | MHz      |  |
| ts∪              | Oscillator Start-up Time     | $C_{L1} = C_{L2} = 22pF - crystal$                                  |              | 5              | 10         |          |  |
| t <sub>SR</sub>  | Supply Rise Time             | 10% to 90%                                                          | 0.01         |                | 100        | ms       |  |
| t <sub>REC</sub> | Supply Recovery Time (1)     |                                                                     | 100          |                |            |          |  |
| Tw               | Minimum Pulse Width          | NMI Pin<br>V <sub>DD</sub> = 5V                                     | 100          |                |            | ns       |  |
|                  |                              | RESET Pin                                                           | 100          |                |            | ns       |  |
| T <sub>WEE</sub> | EEPROM Write Time            | $T_A = 25^{\circ}C$ One Byte<br>$T_A = 85^{\circ}C$ One Byte        |              | 5<br>15        | 10<br>25   | ms<br>ms |  |
| Endurance        | EEPROM WRITE/ERASE<br>Cycles | QA LOT<br>Acceptance Criteria                                       | 300.000      | > 1<br>million |            | cycles   |  |
| Retention        | EEPROM Data Retention        | T <sub>A</sub> = 55°C                                               | 10           |                |            | years    |  |
| CIN              | Input Capacitance            | All Inputs Pins                                                     |              |                | 10         | pF       |  |
| C <sub>OUT</sub> | Output Capacitance           | All Outputs Pins                                                    |              |                | 10         | pF       |  |

Notes:

1. Period for which  $V_{DD}$  has to be connected or at 0V to allow internal Reset function at next power-up.

2. Operation below 0.01 MHz is possible but requires increased supply current.



## I/O PORTS

 $(T_A = -40 \text{ to } +85^{\circ}\text{C} \text{ unless otherwise specified})$ 

| Symbol                 | Parameter                 | Test Condition s                                        |                      | Unit |                      |      |
|------------------------|---------------------------|---------------------------------------------------------|----------------------|------|----------------------|------|
| Symbol                 | Parameter                 | Test Condition's                                        | Min.                 | Тур. | Max.                 | Unit |
| VIL                    | Input Low Level Voltage   | I/O Pins                                                |                      |      | 0.3V <sub>DD</sub>   | V    |
| V <sub>IH</sub>        | Input High Level Voltage  | I/O Pins                                                | $0.7 V_{DD}$         |      |                      | V    |
|                        |                           | I/O Pins,<br>I <sub>O</sub> = 10μA (sink)               |                      |      | 0.1                  | V    |
|                        | Low Level Output Voltage  | I/O Pins, $I_{OL} = V_{DD}x1mA$<br>$V_{DD} = 4.5$ to 6V |                      |      | 0.16xV <sub>DD</sub> | V    |
|                        |                           | I/O Pins, $I_{OL} = 1.6mA$<br>V <sub>DD</sub> = 3V      |                      |      | 0.4                  | V    |
| V <sub>OL</sub>        |                           | I/O Pins, $I_{OL} = V_{DD}x2mA$<br>$V_{DD} = 4.5$ to 6V |                      |      | 0.16xV <sub>DD</sub> | V    |
|                        | Low Level Output Voltage, | I/O Pins, $I_{OL} = 3.2mA$<br>$V_{DD} = 3V$             |                      |      | 0.4                  | V    |
|                        | PB4-PB7 Only              | I/O Pins, $I_{OL} = V_{DD}x4mA$<br>$V_{DD} = 4.5$ to 6V |                      |      | 0.26xV <sub>DD</sub> | V    |
|                        |                           | I/O Pins, $I_{OL} = 6.4mA$<br>$V_{DD} = 3V$             |                      |      | 0.8                  | V    |
| V <sub>он</sub>        | High Level Output Voltage | I/O Pins,<br>I <sub>O</sub> = -10μA (source)            | V <sub>DD</sub> -0.1 |      |                      | V    |
| VОН                    |                           | I/O Pins, $I_{OL} = -V_{DD}x1mA$<br>$V_{DD} = 5.0V$     | 0.6xV <sub>DD</sub>  |      |                      | V    |
| I <sub>IL</sub><br>IIH | Input Leakage Current     | I/O Pins, <sup>(1)</sup>                                |                      | 0.1  | 1.0                  | μA   |
| R <sub>PU</sub>        | Pull-up Resistor          | I/O Pins $V_{IN} = 0V, V_{DD} = 5.0V$                   | 40                   | 100  | 200                  | kΩ   |

Note 1. Pull-up resistor off

## SPI ELECTRICAL CHARACTERISTICS

 $(V_{DD} = 5.0V, T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwhise specified})$ 

| Symbol          | Parameter       | Test Conditions    | Value |      |      | Unit |
|-----------------|-----------------|--------------------|-------|------|------|------|
| Symbol          |                 |                    | Min.  | Тур. | Max. | onit |
| F <sub>CL</sub> | Clock Frequency | applied on PB5/SCL |       |      | 1    | MHz  |
| ts∪             | Set-up Time     | applied on PB6/Sin |       | 50   |      | ns   |
| t <sub>h</sub>  | Hold Time       | applied on PB6/Sin |       | 100  |      | ns   |



#### **A/D CONVERTER CHARACTERISTICS**

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol                          | Parameter                                 | Test Conditions                                        | Value           |      |                 | Unit |
|---------------------------------|-------------------------------------------|--------------------------------------------------------|-----------------|------|-----------------|------|
| Symbol                          |                                           |                                                        | Min.            | Тур. | Max.            |      |
| Res                             | Resolution (3)                            |                                                        |                 | 8    |                 | Bit  |
| A <sub>TOT</sub>                | Total Accuracy (3)                        | f <sub>OSC</sub> > 1.2 MHz<br>f <sub>OSC</sub> > 32kHz |                 |      | ± 2<br>±4       | LSB  |
| tc <sup>(1)</sup>               | Conversion Time                           | f <sub>OSC</sub> = 8MHz                                |                 | 70   |                 | μs   |
| V <sub>AN</sub>                 | Conversion Range                          |                                                        | V <sub>SS</sub> |      | V <sub>DD</sub> | V    |
| ZIR                             | Zero Input Reading                        | Conversion result when $V_{IN} = V_{SS}$               | 00              |      |                 | Hex  |
| FSR                             | Full Scale Reading                        | Conversion result when $V_{IN} = V_{DD}$               |                 |      | FF              | Hex  |
| ADı                             | Analog Input Current During<br>Conversion | V <sub>DD</sub> = 4.5V                                 |                 |      | 1.0             | μA   |
| AC <sub>IN</sub> <sup>(2)</sup> | Analog Input Capacitance                  |                                                        |                 | 2    | 5               | pF   |
| ASI                             | Analog Source Impedance                   |                                                        |                 |      | 30              | kΩ   |
| SSI                             | Analog Reference Supply<br>Impedence      |                                                        |                 |      | 2               | kΩ   |

Notes:

1. With oscillator frequencies less than 1MHz, the A/D Converter accuracy is decreased.

2. Excluding Pad Capacitance

3. Noise at  $V_{DD}$ ,  $V_{SS} \le 10 mV$ 



#### TIMER CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                    | Test Conditions                                                   | Value                |      |                     | Unit     |
|------------------|------------------------------|-------------------------------------------------------------------|----------------------|------|---------------------|----------|
|                  |                              |                                                                   | Min.                 | Тур. | Max.                | Onit     |
| t <sub>RES</sub> | Resolution                   |                                                                   | $\frac{12}{f_{OSC}}$ |      |                     | second   |
| f <sub>IN</sub>  | Input Frequency on TIMER Pin |                                                                   |                      |      | $\frac{f_{OSC}}{8}$ | MHz      |
| tw               | Pulse Width at TIMER Pin     | $\begin{array}{l} V_{DD} \geq 3V \\ V_{DD} \geq 4.5V \end{array}$ | 1<br>125             |      |                     | μs<br>ns |

# LCD ELECTRICAL CHARACTERISTICS

 $(T_A = -40 \text{ to } +85^{\circ}C \text{ unless otherwise specified})$ 

| Symbol           | Parameter                        | Test Conditions                              | Value |      |      | Unit |
|------------------|----------------------------------|----------------------------------------------|-------|------|------|------|
|                  |                                  |                                              | Min.  | Тур. | Max. | onic |
| f <sub>FR</sub>  | Frame Frequency                  | 1/4 Duty<br>f <sub>OSC</sub> = 1, 2, 4, 8MHz | 16    |      | 128  | Hz   |
| V <sub>OS</sub>  | DC Offset Voltage <sup>(1)</sup> | $V_{LCD} = V_{DD}$ , no load                 |       |      | 50   | mV   |
| V <sub>OH</sub>  | COM High Level, Output Voltage   | $I = 100 \mu A V_{LCD} = 5V$                 | 4.5V  |      |      | V    |
| Vol              | COM Low Level, Output Voltage    | $I = 100 \mu A V_{LCD} = 5V$                 |       |      | 0.5V | V    |
| V <sub>OH</sub>  | SEG High Level, Output Voltage   | $I = 50\mu A V_{LCD} = 5V$                   | 4.5V  |      |      | V    |
| V <sub>OL</sub>  | SEG Low Level, Output Voltage    | $I = 50\mu A V_{LCD} = 5V$                   |       |      | 0.5V | V    |
| V <sub>LCD</sub> | Display Voltage                  | Note 2                                       | 3     |      | 10   | V    |

Notes :

1. The DC offset voltage refers to all segment and common outputs. It is the difference between the measured voltage value and nominal value for every voltage level. Ri of voltage meter must be greater than or equal to  $100M\Omega$ .

2. An external resistances network is required when  $V_{\text{LCD}} \leq 4.5 \text{V}.$ 



# PACKAGE MECHANICAL DATA

## Figure 3.ST62E45 52 Pin Ceramic Quad Flat Package with Window





## ST62E45 - ST62T45

#### **ORDERING INFORMATION TABLE**

| Sales Types | Memory type | Temperature Range   | Package  |
|-------------|-------------|---------------------|----------|
| ST62E45G1   | 4K EPROM    | tested at 25°C only | CQFP52-W |
| ST62T45Q6   | 4K EPROM    | -40 to + 85°C       | PQFP52   |

Information furnished is believed to be accurate and reliable. However, SGS-THOMSON Microelectronics assumes no responsibility for the consequences of use of such information nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of SGS-THOMSON Microelectronics. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. SGS-THOMSON Microelectronics products are not authorized for use as critical components in life support devices or systems without the express written approval of SGS-THOMSON Microelectronics.

© 1995 SGS-THOMSON Microelectronics - All rights reserved.

Purchase of I<sup>2</sup>C Components by SGS-THOMSON Microelectronics conveys a license under the Philips I<sup>2</sup>C Patent.

Rights to use these components in an I<sup>2</sup>C system is granted provided that the system conforms to the I<sup>2</sup>C Standard Specification as defined by Philips.

SGS-THOMSON Microelectronics Group of Companies

Australia - Brazil - China - France - Germany - Hong Kong - Italy - Japan - Korea - Malaysia - Malta - Morocco - The Netherlands Singapore - Spain - Sweden - Switzerland - Taiwan - Thailand - United Kingdom - U.S.A.

